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Le point sur l'EAO 


Exemples de Bases de données 
Robots en kit 
La puce vidéo du C64 


Page manquante 
(publicité et colophon) 


Nous terminons notre suite d’articles sur l’enseignement par un tour 
d’horizon des nouvelles perspectives offertes par l’ordinateur en 


matière de méthodes pédagogiques. 


L’Enseignement assisté par ordinateur (E.A..O.) 
est en train de connaître une véritable révolution. 
Matériel moins cher, logiciel plus abouti et amé- 
liorations technologiques concourent à changer 
radicalement l’enseignement auquel nous sommes 
habitués. Loin d’être le parent pauvre des mar- 
chés informatiques, l’enseignement s’impose de 
plus en plus comme le secteur de pointe du déve- 
loppement d’une nouvelle technologie. Ce ren- 
versement de tendance s’explique aisément. 
L’enseignement fut en effet d’abord négligé par 
les informaticiens, constructeurs et éditeurs de 
logiciels, au profit du marché du consommateur, 


beaucoup plus lucratif... La situation change 
rapidement avec la prise de conscience de 
l'importance des marchés éducatifs. L’enfant 
devient une cible pour les publicitaires, qui voient 
en lui un consommateur futur. 

La conséquence immédiate de cette évolution 
est l’amélioration du matériel destiné à l’ensei- 
gnement (moins cher et davantage accessible). 
Apple lança en 1985 une campagne concernant 
la vente de Macintosh aux écoles avec un rabais 
de 30 %. Atari suivit Apple en créant une nou- 
velle gamme de micros ST de 32 bits destinés à 
l’enseignement. Son originalité était de proposer 
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La classe du futur 
L'informatique peut 
révolutionner notre 
conception de 
l'enseignement en faisant 
de l'enfant le centre 
d'intérêt de la méthode 
pédagogique. C'est lui- 
même qui commande 
l'accès aux diverses 
ressources éducatives 
(les informations) mises à 
sa disposition par les 
nouvelles technologies. 
Les transmissions par 
satellite et les systèmes 
de réseau permettent aux 
étudiants de consulter 
des bases de données 
dites « intelligentes » 

à l'autre bout du monde. 
L'accès à d’autres 
cultures est ainsi facilité. 
Les écoles deviendront 
des « centres supervisant 
l'acquisition des 
connaissances ». Les 
enfants s’y rencontreront 
pour confronter leurs 
travaux, dont la quasi- 
totalité pourra être faite 
à domicile. Des systèmes 
vidéo interactifs 
permettront le 
développement de 
logiciels extrêmement 
sophistiqués. Des robots 
pourront être utilisés 
pour des démonstrations 
de concepts physiques 
abstraits. 

(CI. Alan Adler.) 
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Vraisemblance vidéo 
L'utilisation par matière 
des micro-ordinateurs 
concerne avant tout les 
disciplines scientifiques. 
L'introduction des 
systèmes vidéo 
interactifs et le 
développement de 
logiciels sur cette même 
base devraient ouvrir 
l'informatique aux autres 
domaines. Par exemple, 
l'enseignement de 
l'histoire pourrait être 
radicalement changé par 
la pratique de 
simulations complexes 
mettant à profit les 
capacités de stockage 
gigantesques des 
disques vidéo. 

(CI. lan McKinnell.) 
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LOGO en mémoire morte à la place du BASIC. 
En France, par exemple, Thomson, Exelvision, 
Goupil ont été choisis pour s’implanter dans les 
écoles. Les marchés en jeu sont considérables, 
pouvant aller jusqu’à 100 machines par jour. 

En dehors de l’aspect commercial du marché 
éducatif, il s’est également fait jour une nouvelle 
génération d'utilisateurs de micros, qui est plus 
exigeante et recherche des applications plus 
sérieuses. Le développement de programmes édu- 
catifs a maintenant débordé le cadre de l’école, 
et rencontre des marchés plus importants. La 
création de didacticiels est donc devenue plus 
rigoureuse. Le manque de matériel et la pauvreté 
des logiciels ne freinant plus le développement de 
PE.A.O., que peut-on attendre dans ce domaine ? 
L'utilisation de l’ordinateur peut maintenant 
s’orienter dans deux directions : l’extension des 
techniques existantes et l’apparition de méthodes 
radicalement nouvelles. 

Seymour Papert a déjà indiqué un certain 
nombre d’améliorations à apporter au LOGO en 
utilisant la puissance de machines telles que le 
Macintosh. Papert voudrait voir incorporer au 
langage les lois élémentaires de la physique. Cette 
« micro-physique » permettrait aux enfants de 
jouer avec les lois de la gravité, comme ils le font 
avec celles de la géométrie. Il prévoit également 
une base de données « micro-universelle » dans 
laquelle les enfants pourraient librement puiser 
des informations sur le traitement des données. 
Certaines de ces idées ont d’ores et déjà été mises 
en œuvre dans un logiciel, Mac’LOGO. Les simu- 
lations, les programmes d’E.A.O. et les bases de 
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Matières 


10 %o 20 % 30 % 40 % 50 % 60 % 70 % 


% de l'échantillon total des écoles 


données deviendront plus accessibles et effectifs 
avec l’entrée à l’école de programmes de consul- 
tation tels que Filevision de Macintosh. 

Cependant, les perspectives les plus promet- 
teuses en matière d'enseignement par ordinateur 
tiennent à l’introduction de technologies entiè- 
rement nouvelles, telles que les mémoires mor- 
tes sur disques compacts ou les vidéos interacti- 
ves. Une grande capacité de stockage à un prix 
abordable permet de libérer les didacticiels de leur 
contrainte d’organisation linéaire, caractéristique 
des programmes développés sur de petits systè- 
mes non conviviaux. Le degré d’interaction d’un 
programme d’E.A.O. de 48 K est extrêmement 
limité, imposant des contraintes à la méthode 
d’acquisition des connaissances. La vidéo inter- 
active permet une plus grande souplesse dans le 
traitement du sujet, utilisant l’espace mémoire 
accru pour autoriser plusieurs cheminements 
pendant l’exécution des programmes. 

On peut distinguer quatre domaines d’appli- 
cation pour l’utilisation de la vidéo interactive en 
matière d’enseignement par ordinateur. Les 
professeurs pourraient l’utiliser comme aide 
pédagogique par le biais de programmes édu- 
catifs et de références audiovisuelles. L'accès à 
des banques d’images et de films s’en trouverait 
considérablement accéléré. De petits groupes 
d’élèves pourraient l’utiliser comme tuteur, étu- 


| Domesday + 900 


Neuf cents ans après Guillaume le Conquérant 

et son cadastre britannique, le vidéodisque et 

son énorme capacité de stockage de données 
| sont mis à l’épreuve pour réunir toutes sortes 


de données sur la Grande-Bretagne. La BBC, 
Philips, Thorn-Emi ainsi que l'organisme 
d'informatisation des écoles britanniques ont 
mis en œuvre ce projet gigantesque. 

Les écoles doivent collecter des données sur 
leur environnement immédiat, l’ensemble étant 
réuni pour former une banque de données 
publique. Celle-ci comportera des informations 
sur l’utilisation des terres, les services 

et associations diverses, etc. En outre, 

les sources nationales de données devront être 
fusionnées (par exemple, le recensement 

ou les études sur les transports) en üne seule 
et immense base de données nationale. 

Les deux bases tiendront sur un seul 

disque laser. En outre, la technologie du disque 
laser autorise l'enregistrement de cartes, de 
diagrammes, de tables et même de séquences 
de dessins animés. 


diant la documentation et répondant aux ques- 
tions. Les utilisateurs individuels s’en serviraient 
pour des simulations entièrement interactives, des 
didacticiels complexes et des programmes d’ensei- 
gnement très ouverts. En dernier lieu, il ferait 
office d’accès à des données, comme biblio- 
thèque audio et vidéo. 

Bien qu’il reste beaucoup de travail à faire en 
ce qui concerne l’indexation et l’accès aux infor- 
mations avec vidéo interactive, le système est déjà 
bien introduit dans de nombreuses applications. 
Une université britannique l’a utilisé, dans ses 
cours d’été, pour simuler l’effet de forces physi- 
ques sur la matière. Un autre programme l’a mis 
à profit pour créer des masques, des effets d’ani- 
mation et des séquences vidéo. Il s’agissait en 
l’occurrence d’un programme mettant en scène 
une audience d’un tribunal opposant des fabri- 
cants d’ours en peluche (!) et de machines à laver 
(...), le sujet de controverse étant de savoir si les 
yeux desdits ours résisteraient au traitement des 
machines à laver. L’étudiant-interlocuteur de la 
vidéo interactive doit mener à bien un certain 
nombre d’expériences ayant valeur d’expertise. 
Le programme est contrôlé par un didacticiel trai- 
tant les causes possibles de défaillance des maté- 
riaux intervenant dans la fabrication des yeux. 
L'étudiant effectue diverses expériences et en 
interprète les résultats, ces derniers étant finale- 
ment mis en scène. 


Plus d'écoles 


Le transfert des techniques logicielles actuelles 
— simulation, didacticiels, bases de données, 
etc. — vers des systèmes à mémoire morte sur dis- 
que compact est fructueux ; mais les effets à long 
terme de cette nouvelle technologie vont beau- 
coup plus loin. Selon Seymour Papert, « il n’y 
aura plus d’écoles d’ici vingt ans. L’idée d’un 
professeur faisant face à une classe prenant des 
notes est incompatible avec l’informatique. Si 
l’on passe en revue les aspects actuels de l’école, 
on s’aperçoit qu’ils deviennent inutiles et ineffi- 
caces. Par contre, ce qui est aujourd’hui freiné 
— la communication entre enfants — sera favo- 
risé.… Il y aura alors une forme d’organisation 
(qu’on l’appelle ‘‘école”” ou autrement), un lieu 
où les enfants se rencontreront et développeront 
ensemble leur personnalité. Ce qui est important, 
c’est que l’école d’aujourd’hui n’existera plus ». 

Son opinion se trouve développée par le pro- 
fesseur Tom Stonier, qui affirme : « L’ordina- 
teur marquera le début du transfert de l’éduca- 
tion de l’école à la maison. » 

Les implications possibles de cette mutation 
d’une structure pédagogique, centrée sur le 
système scolaire, à une organisation privilégiant 
l'individu sont considérables et dépassent le cadre 
de l’école. 

Selon Stonier, avec l’école à la maison et une 
plus longue espérance de vie (améliorations dues 
aux progrès de la médecine), les personnes âgées 
s’occuperont davantage de l’éducation des 
enfants, comme c’est le cas dans les sociétés dites 
« primitives ». Stonier estime que cette ressource 


inexploitée est tout indiquée pour prendre en 
charge une partie de l’enseignement. 

Il existe aux Etats-Unis une illustration de ce 
que pourrait être un tel système. A Portage, Wis- 
consin, un professeur rend visite à chaque enfant 
une fois par semaine. Il apprécie à cette occasion 
les progrès faits en une semaine, et décide avec 
les parents du travail à donner à l’enfant. 

Bien que l’exemple de Portage concerne des 
enfants handicapés, il pourrait tout aussi bien 
s’appliquer à d’autres étudiants. En Grande- 
Bretagne, il est légal d’instruire vous-même, à 
domicile, vos enfants, si pouvez prouver que vous 
êtes en mesure de le faire. Il y a actuellement plus 
de deux mille familles ayant ainsi retiré leurs 
enfants de l’école. L’accès à de grandes bases de 
données publiques, l’utilisation de micros puis- 
sants à mémoire résidant sur disque compact 
(bases de données) et de logiciels interactifs don- 
neront aux parents-éducateurs de puissants outils 
d’enseignement à domicile. 

Avec l’accroissement en complexité et en diver- 
sité des didacticiels, le rôle des professeurs devient 
de moins en moins aisé à définir. Stonier prédit 
que les enfants deviendront davantage aptes que 
leurs professeurs à acquérir des connaissances. 

En effet, aussi longtemps que les professeurs 
font office de « base de données ambulantes », 
les connaissances acquises par l’enfant sont stric- 
tement limitées par l’intelligence même de son 
professeur. Tous les professeurs d’informatique 
(et d’autres matières) savent qu’il y a des élèves 
qui les ont dépassés. Stonier pense qu’il y en aura 
de plus en plus, avec le développement des bases 
de données et des didacticiels. Les professeurs 
deviendront des conseillers, experts en pédago- 
gie, et non spécialistes d’une matière donnée. 
Ils guideront les élèves dans l’acquisition des 
connaissances, en les suivant, et non en les 
« enseignant ». 


Témoin occulaire 

Les séquences filmées 
et autres informations 
visuelles de haute 
résolution supposent le 
stockage et le traitement 
d'énormes quantités de 
données. Avec les 
systèmes contrôlés par 
ordinateur, c'était tout à 
fait impossible. L'arrivée 
de la technologie de la 
vidéo interactive le 
permet. Ces photos 
d'écran provenant du 
disque de l’« ours en 
peluche » illustrent un 
système de disque vidéo 
contrôlé par ordinateur. 
Il s’agit ici d'un cours 
destiné à des élèves 
ingénieurs. 

Le programme met en 
scène un rapport 
d'expertise devant un 
tribunal. Il simule des 
expériences et établit 
l'arrêt du tribunal. 
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Bimesren. 0 | CONS. | 
Variables importantes 


Nous examinons ici l’utilisation des fonctions et donnons quelques 
exemples qui illustrent l’intégrité structurale stricte et concise du 


langage PASCAL. 


Comme les procédures qui peuvent être définies 
et appelées ultérieurement, les fonctions peuvent 
aussi être appelées, mais uniquement à titre 
d’expressions — non comme instructions. Alors 
que des appels de procédures entraînent l’exécu- 
tion de sous-programmes pour effectuer un trai- 
tement quelconque, les appels de fonction ne font 
que calculer une valeur. Le résultat renvoyé peut 
être de type simple, réel ou scalaire, ou de type 
« pointeur » (que nous avons déjà rencontré). La 
seule différence, en dehors de l’utilisation du mot 
réservé FUNCTION, est que l’identificateur de type 
du résultat donné doit être spécifié. Supposons 
que PASCAL n'ait pas la fonction prédéfinie odd 
— nous pourrions facilement définir la nôtre : 


FUNCTION Odd Inombre:entierl:booléen:; 
BEGIN 
Odd:=nombre MOD2>0 
END; {Odd] 


La valeur est renvoyée dans l’identificateur de la 
fonction et, par conséquent, doit lui être attri- 
buée dans le corps de la fonction. De ce point 
de vue, les noms de fonction sont similaires à des 
variables qui ne sont jamais initialisées, mais leurs 
valeurs sont calculées lorsqu’elles apparaissent 
dans une expression. Elles ne peuvent apparaî- 
tre que du côté gauche d’une affectation; ainsi, 
si nous programmons l'affectation de la façon 
suivante : 


IF nombre MOD 250 THEN 
Odd:= vrai 


(en oubliant la clause nécessaire ELSE Odd: = faux), il 
est possible de passer outre à cette construction, 
laissant ainsi le résultat indéfini. 

Comme pour les paramètres de procédures que 
nous avons examinés jusqu'ici, la valeur du para- 
mètre est fournie à l’identificateur entier local, 
nombre, à partir du « point d’activation ». Ainsi : 


WriteLn (Odd (carré (N DIV 100))) 


qui imprimerait toujours faux, effectue trois opé- 
rations : 
1. L'expression N DIV 100 est calculée. 
2. Cette valeur entière temporaire est four- 
nie à carré comme paramètre de valeur. 
3. Son carré est renvoyé et fourni à Odd. 
4. Le résultat booléen est maintenant éva- 
lué et fourni à la procédure Writeln comme 
un autre paramètre de valeur. 
Si N avait eu la valeur {7 lorsque l’instruction ci- 
dessus était exécutée, quelle aurait été ensuite sa 
valeur ? Cette question peut sembler ridicule, évi- 


demment. Il n’y a aucune raison pour que la 
valeur N change pendant l'évaluation d’une 
autre fonction impliquant N comme paramètre. 
Les résultats de toutes les fonctions ne doivent 
dépendre que de l’état des choses telles qu’elles 
existent. C’est-à-dire que la valeur renvoyée est 
fonction des valeurs de ses arguments ou para- 
mètres. Le mécanisme PASCAL qui permet de 
fournir uniquement la valeur des variables garan- 
tit que, même si les paramètres sont changés loca- 
lement (et parce qu’ils ne sont en fait que des 
copies locales), les véritables paramètres ne seront 
pas modifiés au point d’activation. 

Pour ces raisons, bien que PASCAL ne l’inter- 
dise pas, on ne devrait pas avoir accès globale- 
ment aux données. Toutes les liaisons entre les 
appels de procédures et de fonction doivent être 
commandées par des listes de paramètres — 
même si les données se situent à l’intérieur du 
domaine du sous-programme. La seule exception 
à cette règle générale concerne l’accès à des 
constantes globales. En raison de leur nature, il 
est tout à fait impossible de modifier leurs 
valeurs. Cependant, si une valeur constante est 
fournie comme paramètre, elle devient une varia- 
ble locale et n’est donc plus immuable. 


FUNCTION Minuscule (character:char) :char; 
{renvoie la minuscule de tout argument majuscule] 
CONST 

décalé = 32; {ASCII ord l'a‘) — ord l'A'}} 


BEGIN 
IF character IN ['A'. 71 
THEN 
Minuscule: = char ( ord{character]) + décalé) 
ELSE 


Minuscule: = character 
END; {Minusculel 


Lorsque nous définissons des procédures, il est 
quelquefois essentiel qu’elles modifient les 
valeurs de leurs paramètres — sinon elles n’exé- 
cuteraient pas la tâche pour laquelle elles ont été 
conçues. La procédure PASCAL read en donne un 
bon exemple. Il ne serait pas très pratique si 
read (N) ne donnait qu’une valeur à une variable 
entière locale à read et si la valeur de N demeurait 
inchangée. Dans de telles situations, nous devons 
fournir l’adresse d’un paramètre variable (et non 
sa valeur) afin que la procédure puisse y référer 
directement plutôt qu’à une copie locale. Ce 
mécanisme se nomme « fournir par adresse » ou 
« par référence » et ne doit être normalement uti- 
lisé que par les procédures et non par les 
fonctions. 


= 
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Pour fournir des paramètres variables, il suf- 
fit simplement d’inclure le mot réservé VAR avant 
tout item compris dans la liste de paramètres de 
la procédure. La syntaxe d’une liste de paramè- 
tres est en quelque sorte semblable à la déclara- 
tion VAR d’un bloc; mais au lieu de n’apparaître 
qu’une fois comme délimiteur, il n’apparaît que 
devant un élément qui doit être modifié par une 
procédure. Par exemple : 


PROCEDURE Process (VAR Compteur :ComptListe); 

Illustrons cette technique puissante en mettant 
au point un programme qui lit quelques noms au 
clavier et, associé à chaque nom, un montant 
d’argent que chaque personne nous doit. Pour 
simplifier, nous n’utiliserons qu’une chaîne par 
nom et exprimerons les dettes sous forme de 
francs. Dès que notre programme est testé, nous 
pouvons ajouter d’autres détails comme les 
adresses, les numéros de téléphone et ainsi de 
suite. Nous aimerions imprimer la liste des noms 
soit par ordre alphabétique, soit, si possible, dans 
un ordre croissant de sommes dues. La structure 
naturelle de données est une liste d’enregistre- 
ments renfermant des zones de type approprié 
pouvant facilement être ajoutées ultérieurement. 
Nous pouvons manipuler chaque enregistrement 
comme un élément unique de donnée, mais uti- 
liser toute zone comme clé de tri. Nous devons 
concevoir la représentation des données : 


CONST 
LongueurChaîne = 20; 
LongueurListe  =50; 


Avantages 


Le programme CardReader ee EN = @.. Maxinti 5 | BEGIN 
1 N := 0: 1" 


manipule des nombres 


LecteurdeCarte ( entrée, sortie )3 


TYPE 

Cardinal =0..Maxint:; 

TailleChaîne  =1..LongueurChaîne; 

Chaîne =PACKED ARRAY [TailleChaîne] OF char; 
data = RECORD 


nom : chaîne 
autre zone à adapter] debt : Cardinal; 
END; {données| 
débits = 1..LongueurListe; 
EnregistrementListe= ARRAY [débits] OF données, 


Cela permet l’utilisation de cinquante noms et 
suppose (pour maintenant) qu'aucun nom ne 
comptera plus de vingt caractères, mais en utili- 
sant des définitions, nous pouvons changer ceci. 
Nous avons exprimé toutes les fourchettes et les 
structures dans une partie de définition TYPE 
pour plusieurs raisons : 
1. La sécurité — un index de type bounds ne 
peut jamais excéder les limites définies d’un 
tableau, par exemple. 
2. La mise au point — si une « erreur de four- 
chette » survenait lors des tests, le message 
d’erreur faciliterait la localisation du problème. 
3. L'efficacité — les variables locales peuvent 
être de « types existants », ce qui évite la dupli- 
cation et économise de la mémoire. 
4. La nécessité — PASCAL exige que les indi- 
cateurs de type de paramètre soient des iden- 
tificateurs et non des constantes (0...255, par 
exemple). 
Ensuite, nous devons songer à concevoir quelques 
variables essentielles et un algorithme. 


OK := symbole IN nombres 


[d IF OK THEN rt 


positifs d'une manière très 
sûre en lisant les données 
comme des caractères. La 
conversion en une valeur 
numérique équivalente est 
effectuée simplement en 
soustrayant la valeur 
d'origine du caractère ; 
chiffre de celle du chiffre 0. 
Ceci fonctionnera pour 
tous les jeux de caractères 
puisque les caractères 0 à 9 
sont définis comme étant 
contigus. Notez que le 
programme n'a que deux 
variables globales 

(au niveau 1). 

Les données de traitement 
des nombres et la fonction 
Vale, qui se charge d'établir 
les correspondances, ne 
sont utilisées que par 
ReadCard, et ne sont donc 
déclarées et définies qu’à 
l'intérieur de cette 
procédure. 14 \ 

Il n'y a qu'un problème 
dans ce programme : si 
une valeur supérieure aux 
entiers prévus (Marnt) est 
entrée, l'instruction 
d'affectation dans la 
boucle WHILE bloquera 
l'exécution. ns 


PostNum ? cardinal 
Okay 1 booléeni 


Jiitiitit111111111111111111111111} 


PROCEDURE LireCarte ( VAR N * cardinali 
VAR OK : booiéen )3 
CONST 


symbole ? Char: 
nombres 3: SET OF char: 
Ÿ222222222222222222222222| 
jni veau 2} 

FUNCTION Valeur ( nombre : char ) 5 sinsies 
fRetourne la valeur numérique d’un 
chiffre sur tout jeu de caractère} 

BEGIN 
Valeur := grd C nombre ) - ord € *@' ) 
END: jvaleur} 
222222222222222222222222 
jde retour au TE 1} 


Î 


BEGIN jLireCarte} 


REPEAT 
lire (€ symbole) 


UNTIL symbole > espace 


nombres := C "@' .. "9" J; 


WHILE symbole IN nombres DO 
BEGIN {caicule la base 10} 
Ni= 18 « N+ Vaieurt  symbole)i 
lit € symbole) ne 
END tout caractère dél imi teur ou-*EoLn'} 
END japrès le nombre est suserimé! 


END: ÎLireCarte } 
‘1ÿ111111111111111111111111111111} 
BEGIN }LecteurCarte - Prosramme #rincipai niveau 0} 


pase ( sortie )3 
Writelns 
uriteln (' Ce programme lit des entiers positifs )3 
Writeln ( dans ia fourchette @..', 

MaxInt # 1, " ) 23 
Writeln ( La fin du prosramme est' ): - 
Writeln ( Contréiée par détection d'erreur’ )3 
Uritelns x 
Write ( * Entrez un nombre : * )3 
ReadCard ( PosNom okay )3 


MHILE okay DO 

BEGIN i 
Writelns : 
Write ( ’Le nombre entré est : "): 
Writeln € PosNom : 1 )5 
Write € "Nombre? * )5 
ReadCard ( PosNom, okay 

END; 


Writeln € *--- ERREUR DETECTÉE ---’ : 49 ) 
END . 
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Nous allons donner plusieurs 
exemples qui mettent en œuvre 
des bases de données 

« unidimensionnelles » classiques. 


Un enregistrement est, dans une base de données 
conventionnelle, presque entièrement autonome : 
il contient toute l’information nécessaire, sans 
qu’il soit besoin de se référer à un autre élément. 
Les fiches cartonnées des bibliothèques sont de 
ce type. Chacune d’elles se réduit à la juxtaposi- 
tion de certaines zones : TITRE, AUTEUR, ÉDITEUR et 
ISBN (International Standard Book Number; 
numéro d’identification). Il n’est nul besoin de 
chercher plus loin. 

Parfois il arrive qu’une zone donnée contienne 
une entrée qui constitue un enregistrement à elle 
seule. C’est ainsi que dans le fichier des membres 
d’une association, ENFANTS peut renvoyer à 
d’autres enregistrements : si les fils d’un mem- 
bre sont eux-mêmes membres, ils auront droit à 
une fiche spécifique. Mais une zone peut aussi 
faire référence à des enregistrements qui ne s’intè- 
grent pas bien dans la structure générale du 
fichier. Considérons l’exemple d’une base de 
données intitulée PIÈCES, et qui est divisée en qua- 
tre zones : NUMERO, PRIX, STOCK et FOURNISSEUR. II est 
plus que probable que FOURNISSEUR renverra à 
d’autres enregistrements qui ne pourront être 
répartis dans la base de données telle qu’elle a 
été définie. 

Pour illustrer ce point, voici tout d’abord le 
fichier MEMBRES DE L'ASSOCIATION : 


NOM Pichegru 
ANNÉE D'INSCRIPTION 1979 
COTISATION Réglée 
PROFESSION Enseignant 
SALAIRE 90 000 
ENFANTS Jacques ; Sylvie 


La zone ENFANTS contient dans cet exemple deux 
entrées, et les deux enfants pourraient bien sûr 
faire partie du même fichier à titre personnel, s’ils 
étaient aussi membres de l’association. Compa- 
rons cela à la base de données PIÈCES 


NUMÉRO 3995 
PRIX 34.75 
STOCK 86 


DESCRIPTION Bouchon de carburateur 
FOURNISSEUR  Widgerama Ltd. ; Dongle Corp. de Taiwan 


Là encore, il y a deux entrées dans la zone 
FOURNISSEUR; mais aucune d’entre elles ne pour- 
rait se voir accorder un enregistrement particu- 
lier. Il faudrait donc que la base de données com- 
porte un second fichier réservé aux fournisseurs, 
dans lequel chaque fiche aurait une allure de 
ce type : 


FOURNISSEUR Dongle Corp., Taiwan 
ADRESSE 57 Kau Moo Road, Taipei, Taiwan 
TÉLÉPHONE 010-886-2-223-4478 
FOURNITURES1 Bouchon de carburateur 
PRIX 1 ($US) 12.45 

FOURNITURES? Antigel (bidon 1/2 litre} 
PRIX 2 ($SUS) 6.32 

FOURNITURES3 Poudre à polir (petit bidon} 
PRIX 3 ($US) 3.27 

FOURNITURES4 Poudre à polir (grand bidon} 
PRIX 4 ($US) 6.11 

FOURNITURES5 - 


Il est bien évident que les informations dont nous 
avons besoin, s’agissant des fournisseurs, sont 
tout à fait différentes de celles relatives aux 
pièces qu’ils fournissent. La seule solution 
consiste donc à créer deux bases de données : un 
fichier pièces, un autre consacré à ceux qui les 
distribuent. 

Si l’on veut toutefois s’en servir de façon pro- 
ductive, il est clair que le logiciel de gestion de 
l’ensemble devra être capable de gérer simulta- 
nément plus d’un fichier. Les programmes les 
plus simples n’en sont malheureusement pas 
capables, mais d’autres, comme dBase II, peu- 
vent se servir d’un fichier (ainsi PIÈCES) comme 
fichier « primaire » et d’un autre (disons FOUR- 
NISSEURS) comme fichier « secondaire ». Si le 
logiciel est particulièrement sophistiqué, il doit 
pouvoir effectuer un tri sur le premier (pour en 
extraire des enregistrements) et aussi rechercher 
les enregistrements nécessaires (FOURNISSEURS) 
dans les fichiers apparentés. 

dBase II permet l’emploi simultané de deux 
fichiers, qu’il associe en leur attribuant des clés 
communes. Deux commandes permettent le pas- 
sage des références de l’un à l’autre : SELECT PRI- 
MARY et SELECT SECONDARY. Si le fichier primaire est 
PIÈCES et le second FOURNISSEURS, alors que nous 
sommes en train de travailler sur le fichier PIÈCES, 


Ordre et progrès 

On peut mettre au point un 

système de fiches 

cartonnées aussi complexe 

que l’on voudra. Les 

logiciels de gestion de 

bases de données doivent, 

quant à eux, adopter une 

démarche structurée pour 

manipuler les informations. 

Les plus élaborés d’entre 

eux doivent permettre à 

l'usager d'appeler des 

fichiers reliés entre eux, et, 

lorsqu'il entre des données, 

de supprimer certaines 

zones rendues inutiles par 

d’autres éléments de 

l'enregistrement. Une pièce 

automobile ne sera par 
exemple commandée que si 
le stock est en dessous 
d'un certain niveau (ou s'il 
est déjà tombé à zéro). 
(CI. Kevin Jones.) 


nous pourrons faire usage de la commande USE 
PIÈCES. Si à partir de là nous voulions faire des 
références croisées au fichier des fournisseurs, 
nous taperions SELECT SECONDARY suivi, ligne sui- 
vante, de USEFOURNISSEURS. Les nombreuses com- 
mandes du programme seraient à notre disposi- 
tion et s’appliqueraient au fichier sélectionné en 
dernier lieu. 

Il arrive parfois que le contenu d’une zone par- 
ticulière (ainsi FOURNISSEURS dans le fichier 
PIÈCES déjà étudié) n’ait pas besoin d’être indivi- 
dualisé (organisée en un fichier séparé). Les dif- 
férentes zones d’un enregistrement devraient suf- 
fire dans ce cas. Supposons que vous ayez créé 
une base de données consacrée à la technologie 
automobile et à ses récents développements. Vous 
y classeriez des articles de presse et des réfé- 
rences de livres consacrés, entre autres, aux caros- 
series en plastique moulé ou aux alimentations 
à injection. Le format de base pourrait être 
celui-ci : 

SUJET 

RÉSUMÉ 

RÉSUMÉ? 

RÉSUMÉ3 

SOURCE 

TITRE 

DATE 

PAGE 
Si vous avez trouvé la référence dans une revue, 
le numéro d’ISBN ne sera d’aucune utilité puisque 
les magazines en sont dépourvus. Si, par contre, 
il s’agissait d’un livre intitulé /a Programmation 
des microprocesseurs pour la conduite automo- 
bile intégrée, vous auriez besoin de cette indica- 
tion. De même, vous auriez un numéro de page 
dans les deux cas. Cela n’aurait pas lieu d’être, 
si vous aviez trouvé le renseignement à l’occasion 
d’une émission de télévision sur TF1. Certains 
programmes, comme Rescue, de Microcompu- 
ter Systems, permettent l’absence ou la présence 
de telle ou telle zone dans un enregistrement par- 
ticulier qui dépend d’autres champs précédem- 
ment définis. 


ISBN 


C’est ainsi que si SOURCE n’est pas un livre, le 
numéro d’ISBN ne sera pas pris en ligne de 
compte, et donc ne sera pas affiché sur l’écran 
comme sur l’imprimante. Si cette source n’est ni 
un livre ni une revue, PAGE sera mis à l’écart. Un 
logiciel de gestion capable de manœuvres de ce 
genre peut ainsi économiser de l’espace mémoire, 
en éliminant les zones inutiles. Cela permet aussi 
d’améliorer la présentation. Toutefois, il restera 
moins souple d'emploi qu’un programme capa- 
ble de relier des enregistrements répartis sur deux 
fichiers différents. 

Il se peut qu’une base de données comporte des 
informations qui restent constantes pour chaque 
enregistrement, ainsi que certaines données qui 
peuvent, ou non, être mises en œuvre; c’est ce 
qu’on appelle une « hiérarchie à deux niveaux ». 
En règle générale, les logiciels de gestion multi- 
fichiers traitent les renseignements de ce type 
comme un cas particulier, ou un sous-ensemble, 
d’une base de données à fichiers multiples. Une 
référence à un livre (SOURCE) pourrait renvoyer à 
un fichier LIVRES, par exemple. 

Il reste à considérer un dernier élément. Vous 
pouvez mettre au point un système de fiches car- 
tonnées qui sera aussi complexe et sophistiqué 
que vous le voudrez. Mais la plupart des gestion- 
naires de base de données ont des limites, selon 
ce qu’ils peuvent ou ne peuvent pas accepter. 
C’est pourquoi, avant d’en acquérir un pour 
votre micro-ordinateur, il est très important 
d’avoir une idée précise de ce que vous comptez 
lui demander. Rassemblez vos exigences et exa- 
minez de près les caractéristiques de chaque pro- 
gramme avant de prendre une décision définitive. 


Betabase disquette 


DFM 
Database 


Practifile 
Software 
Associates 


# ù 


Long max. enregistr. 2048 
Taille max. fichier 99 K 
(40 T), 199 K (80 T) 

Max. champs 200. 


| Enregist. définis 


[par usager. 


15 zones/enregistr. 
Zone alphanum. 36 car. 
Zone numérique 

9 chiffres. 


3 800 enregistr./fichiers 
Réorganisation données 
pour courrier 
électronique. 

Entrée par lots. 


Contient traitement de 
texte et tableur. Long. 


|max. enregistr. 1024. 
[Nb max. d’enregistr. par 
fichier 32750. 
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Nous terminons ce type de test par un nouveau problème entre 
variables et constantes. Comme quoi l’étude des organigrammes est 
importante... et pas seulement pour les débutants. 


Dans ce deuxième organigramme, la dernière 
question de la série éliminatoire d’opérations à 
réaliser a été supprimée. Ainsi, l’on peut consta- 
ter l’introduction d’une comparaison, pour 
savoir si un nombre donné se situe entre un et 
quatre ; néanmoins, il existe un autre problème : 
qu’arriverait-il si l’on introduisait, à ce même 


niveau, un nombre qui comporterait des déci- 
males? Grâce à la deuxième question (qui véri- 
fie si le nombre est un entier ou non), on élimine 
cette possibilité et on a la certitude que nul élé- 
ment étranger ne peut y entrer. 

Toute information introduite sera détournée 
sur une quelconque voie. Par exemple, en 
excluant la première question, un nombre erroné 
(7, par exemple) aurait « descendu » l’organi- 
gramme et, comme il n’existe pas de contrôle 
après le code 3, il aurait obtenu au passage de 
ce code une réponse négative. De ce fait, la déci- 
sion d’exécuter la division serait intervenue. 


IREM "#"""" COUDES 

20 INPUT « PREMIÈRE QUANTITÉ »;A 

30 INPUT « SECONDE QUANTITÉ »;B 

33 REM ********** ENTRÉE CODE 

40 INPUT « CODE... »:C 

45 REM ***"°"**®° AILTRES 

50 IF C<1 OR C >4 THEN GOTO 40 

60 IF C<>INT(C) THEN GOTO 40 

70 REM ********** DÉCISIONS 

80 IF C=1 THEN PRINT « LA SOMME EST »; A+B: 
END 

00 IF C=2 THEN PRINT « LA SOUSTRACTION EST »; A-B: 
END 

100 IF C=3 THEN PRINT « LA MULTIPLICATION EST »; A*B: 

END 

110 IF B=0 THEN GOTO 30 

120 PRINT « LA DIVISION EST »; A/B 

125 END 


RQ 
Kit pour six robots 


Fischertechnik vous propose de construire avec ses éléments en kit 
six types de robot, ou de concevoir votre propre modèle. Cela vous 
garantit plusieurs heures de travail et de découvertes. 


A 


Bien que de nombreux spécialistes de l’informa- 
tique grand public prédisent depuis un certain 
temps que l’avenir de l’industrie se situe dans le 
développement de la robotique domestique, ces 
prévisions ne se sont pas toujours révélées exac- 
tes. Ce n’est pas difficile à comprendre. Malgré 
le fait qu’au cours de la dernière année de nom- 
breux « robots domestiques » soient apparus sur 
le marché, ils ont présenté quelques problèmes 
importants. Ces difficultés ont compromis 
l’enthousiasme que ce projet aurait dû susciter 
auprès du public. 

Il existe d’une part des robots faciles à cons- 
truire, comme les Movits, qui peuvent être assem- 
blés en quelques heures par une personne qui ne 
connaît rien en robotique ou même en électroni- 
que. Ces unités ont cependant des applications 
très limitées, et elles ne suscitent pas un intérêt 
très durable chez l’utilisateur. D’autre part, des 
robots plus coûteux sont disponibles mais néces- 
sitent généralement une connaissance étendue de 
la robotique et de l’électronique pour les utiliser. 
Même dans ce cas, plusieurs de ces robots évo- 
lués n’ont qu’un seul usage. De nouveau, cela 
signifie que l’utilisateur abandonne rapidement 
ce qui est devenu un gadget inutile. 

Le robot idéal serait donc facile à construire 
et doté de différentes fonctions que l’utilisateur 
pourrait expérimenter facilement. Le kit roboti- 
que de Fischertechnik est censé réunir ces carac- 
téristiques. L’approche des concepteurs de ce 
produit est très simple. Il existe depuis mainte- 
nant quelques années de nombreux kits électro- 
niques destinés aux enfants qui leur permettent 
de construire des circuits électroniques assez sim- 
ples pour assembler un poste radio, par exem- 
ple. Le même kit peut être ensuite démonté et 
reconstruit pour former un dispositif de chrono- 
métrage électronique ou une alarme contre le vol. 
Simultanément, des générations d’enfants ont 
grandi en s’amusant avec des kits Lego qui peu- 
vent être utilisés et réutilisés pour construire une 
quantité énorme de modèles différents à partir 
des mêmes petits blocs en plastique. Lors de la 
conception de son kit électronique, Fischertech- 
nik a adopté ces deux approches et les a associées 
à la technologie informatique moderne pour met- 
tre au point un produit qui pourrait réussir la per- 
cée commerciale que de nombreuses personnes 
ont prédite pour la robotique. 

Le kit Robotics permet à l’utilisateur de cons- 
truire de nombreuses unités robots différentes 
pouvant être commandées à partir d’un micro 
domestique. Il est ainsi possible de construire un 


bras robot, une machine qui trie des articles de 
diverses longueurs, un traceur et un dispositif 
d’entrée graphique. Dès que l’utilisateur connaît 
à fond un robot, il peut le démonter et en recons- 
truire un autre. Afin de commander le robot à 
partir d’un ordinateur, une interface est néces- 
saire pour transformer les signaux numériques 
provenant de l’ordinateur en des signaux qui peu- 
vent servir à actionner les moteurs électriques 
du kit. 

Formés de nombreuses pièces en plastique, les 
composants du kit de construction peuvent être 
emboîtés les uns dans les autres — un peu comme 
un kit Lego — pour constituer différents modè- 
les. Ces pièces prennent l’aspect de blocs qui peu- 
vent être assemblés pour former les bras, ou uti- 
lisés pour abriter les unités de commande. II y 


Contrôle du 
mouvement 


aceur-10Pi 


Voici les écrans 
d'introduction du logiciel 
d'interface Unilab. La 
photographie inférieure 
montre un affichage du 
programme de commande 
du bras-robot. Dans le 
coin supérieur droit 
apparaît un diagramme 
qui illustre le mouvement 
horizontal du robot. On 
suppose que la position 
de départ du robot est 0 
Lorsque le bras-robot 
se déplace vers la droite 
(la ligne se déplace dans 
le sens des aiguilles 
d'une montre), le nombre 
de degrés augmente 
Similairement, lorsque 
l'extension du bras est 
déplacée, la ligne du 
diagramme et la distance 
changeront dans la même 
proportion. Au bas de 
l'écran apparaissent les 
diverses options de 
commande. Celles-là sont 
commandées au moyen de 
micro-interrupteurs situés 
Sur la carte ou à partir du 
clavier. Des séquences de 
mouvement peuvent être 
stockées dans l'ordinateur, 
appelées ultérieurement 
et réexécutées 
Le même système de 
commande est utilisé 
avec le traceur-robot 
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a aussi d’autres pièces, comme des roues d’engre- 
nage et des vis d’entraînement. Une grande carte 
en plastique mesurant 260 mm sur 187 sert de 
base pour le robot lui-même ou, si un traceur ou 
une tablette graphique sont intégrés, comme sup- 
port pour le papier. Les commandes électriques 
et le système d’alimentation doivent aussi être 
assemblés séparément à partir de divers compo- 
sants. Le kit comprend de nombreuses prises 
mâles et femelles, huit dispositifs de commuta- 
tion et une paire de moteurs électriques. On 
trouve également environ 1 mètre de câble-ruban 
à 20 voies et un bout de câble supplémentaire 
pour construire les connexions internes. 

Dans l’ensemble, les pièces sont assez robustes 
et semblent promettre une longue durée d’utili- 
sation, à l’exception peut-être des potentiomètres. 
La plaque de base de l’un de ceux-ci a été abf- 
mée lors de la construction, et bien que cela ne 
gêne pas le fonctionnement du bras (voir la pho- 
tographie), puisque la plaque de base a tout de 
même pu être installée, cela met en doute la fia- 
bilité à long terme. Une autre remarque, concer- 
nant les potentiomètres, est que, contrairement 
au reste des composants électriques qui peuvent 
être vissés dans des prises, les fils nus ne peuvent 
être fixés sur ces unités que s’ils sont enroulés 
autour des connecteurs. Nous recommandons 
donc de souder les joints de façon permanente 
si l’on prévoit de faire un usage intensif du robot 
afin d’éviter que ne se produisent des courts- 
circuits qui pourraient endommager les 
potentiomètres. 


Installation des composants 


La construction des robots est assez simple, et 
les pièces sont de taille suffisante pour ne pas 
avoir besoin d’outil de précision. Le principal 
problème de construction provient du manuel, 
qui constitue probablement la plus grande fai- 
blesse du système. Bien qu’il ait des points forts 
— par exemple, les connexions de circuits sont 
faciles à comprendre —, le manuel renferme des 
photographies de qualité médiocre des modèles 
en cours de construction. Les photographies des 
pièces requises pour une section particulière sont 
accompagnées de vues éclatées du robot en cons- 
truction. Elles ne comportent malheureusement 
pas beaucoup de détails et ne sont pas assez anno- 
tées, ce qui signifie que les utilisateurs devront 
parfois examiner les photographies assez longue- 
ment avant de savoir où placer les diverses piè- 
ces. De plus, comme les photographies ne mon- 
trent le robot que dans un seul plan, vous devrez 
souvent deviner où doit être installée une pièce 
lorsque sa position n’est pas visible. 

Pire encore, les photos sont en noir et blanc. 
Cela signifie que lorsque vous effectuez la der- 
nière partie de la construction, qui consiste à 
monter le circuit électrique du robot, il est pres- 
que impossible de découvrir quelle est la vérita- 
ble procédure de câblage. C’est particulièrement 
étrange lorsque l’on songe que les circuits dépen- 
dent en grande partie du codage couleur du câble- 
ruban. Les annotations minimales fournies dans 
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La barre de métal située sur 
l’électro-aimant glisse à 
l'intérieur du dispositif de saisie 
du bras-robot. L'électro- Ê 
aimant peut être mis en 
fonction et hors 
fonction, ce qui permet 
au robot de soulever 
les petites plaques 
métalliques fournies. 


Potentiomètre 

Les potentiomètres servent et 
fournissent une réaction 

et communiquent la position 
du robot. 


Le moteur 
Le moteur est logé dans un 
boîtier en plastique. La 
connexion au moteur est 
établie au moyen de 
deux prises qui se 
trouvent sur le 
boîtier. 


Voyants 
Lorsque l'un des trois 
systèmes de commande 
principaux (électro- 
aimant, horizontal ou 
vertical) est activé, l’un 
des trois voyants 
s'allume pour indiquer à 
l'utilisateur quelle 
commande est utilisée. 


les diagrammes de montage n’apportent guère 
d’aide, indiquant à peine, par exemple, que 
les fils E3 à E8 appartiennent à une section 
particulière. 

Cela étant dit, nous devons souligner que le 
robot présenté ici a été construit par une personne 
n’ayant aucune connaissance en robotique ou en 
électronique, et qu’elle a réussi à faire fonction- 
ner le robot. Il eût été préférable, toutefois, que 
Fischertechnik ne s’en soit pas remis au bon juge- 
ment des gens mais ait simplement fourni un 
meilleur manuel de construction. 

Lorsque la construction du robot est terminée, 
la tâche suivante consiste à le connecter à l’inter- 
face. Ici, heureusement, la procédure est beau- 
coup plus simple. La carte d’interface est com- 
posée de nombreuses prises divisées en sections 
servant àrecevoir les conducteurs du câble-ruban. 


Commutateur 

En appuyant en même temps 
sur certains de ces 
commutateurs, un nombre est 
généré et est stocké dans le 
registre du port utilisateur, ce 
qui peut servir à commander 
directement le robot. 


Interface 
Pour permettre au kit Robotics d'être commandé par le 
Micro BBC, vous devez acheter l'interface Unilab. Les 
conducteurs provenant du robot sont connectés aux 
prises associées sur la carte d'interface, qui est alors 
reliée au micro par l'intermédiaire des ports. 


Disques métalliques 
Les disques métalliques 
permettent l'exécution 
des travaux mécaniques 
du robot. 


Mécanisme 
d’engrenage 

Les deux moteurs 
électriques produisent les 
mouvements du robot au 
moyen d'un mécanisme 
d’'engrenage complexe 
qui, bien qu'indirect, 
fonctionne très bien. 


côté droit de la carte. La logique des entr 
commutateurs est commandée par le 
données et par le registre de direction des pi 
. nées du micro; son fonctionnement est simil: 
à celui du boîtier tampon que nous avons < éjà 
construit. Plus bas, on retrouve une paire de 
potentiomètres qui permettent à l'ordinateur de 
contrôler l’alimentation fournie aux 
teurs et aux ampoules. Le contrôle des pote 
mètres est assuré par l’intermédaire du 


analogique. 


De l’autre côté de la carte d’interface, on aper- 
çoit des connexions servant à commander les 
moteurs et l’électro-aimant (ce dernier est utilisé 
par le bras-robot pour saisir des objets métalli- 
ques). Finalement, il y a une prise d’alimentation 
de 6 à 8 V, qui alimente le système au complet. 

L'interface est connectée au micro via trois 
ports séparés — le port utilisateur, le port ana- 
logique et le port imprimante — utilisés pour 
commander les moteurs et l’électro-aimant. Puis- 
que le système est destiné à des utilisateurs inex- 
périmentés, la carte d’interface a été construite 
de façon à éliminer la possibilité d’un câblage ina- 
déquat qui pourrait conduire à appliquer aux 
interfaces de l’ordinateur des tensions pouvant 
endommager ses circuits. 

Le manuel qui est fourni pour l’interface (écrit 
par le fabricant du produit, Unilab) est de bien 
meilleure qualité que le manuel de Fischertech- 
nik Robotics. On y trouve une explication détail- 
lée du montage de l’interface et de l’exécution du 
logiciel qui accompagne le système. On trouve 
également un bref résumé des adresses de com- 
mande utilisées, ce qui permet de commander les 
robots à partir de BASIC. Cependant, les dia- 
grammes de montage semblent ne pas correspon- 
dre aux circuits Fischertechnik. Bien qu’une note 
relative aux divers câbles-rubans soit fournie avec 
l’interface, elle ne réussit pas, semble-t-il, à 
résoudre tous les problèmes et, de nouveau, vous 
devrez utiliser votre bon sens pour déterminer 
comment monter correctement le circuit. 


Le langage prof 

Une cassette renfermant trois programmes ser- 
vant à faciliter la commande des robots accom- 
pagne l'interface. Les deux premiers sont des pro- 
grammes spécialisés qui commandent le bras et 
le traceur, ce qui permet aux unités externes 
d’être commandées soit du clavier, soit des com- 
mutateurs de commande situés sur le robot 
lui-même. 

Le troisième programme est Prof, un système 
d’exploitation général qui permet de commander 
directement les robots. Il s’agit essentiellement 
d’une extension du BASIC, comprenant quelques 
commandes supplémentaires. Plusieurs des mots 
introduits par Prof sont des noms de variables, 
comme Motor et Magnet, désignant les adresses de 
commande, tandis que d’autres sont introduits 
pour faciliter l’édition des séquences d’interven- 
tions devant être effectuées par les robots. 

Bien que Prof soit assez complet et permette 
d’insérer des boucles conditionnelles et de 
concevoir une programmation structurée, il est 
limité principalement à la commande de la sor- 
tie. Par conséquent, le panneau graphique, une 
unité d’entrée, n’est pas pris en charge par Prof, 
ce langage ne prévoyant aucun stockage de 
l'information provenant de dispositifs d’entrée. 
Cela vous oblige à créer vos propres program- 
mes en BASIC. 

Malgré les problèmes posés par la documen- 
tation, le kit Robotics et son interface compo- 
sent un système assez intéressant. 


1671 


D | 
Problèmes metipies 


”"Q 
se conséquences que ceux que nous avons déjà 


Æ 


F a 


plan, qui auront des conséquence 


ms +5 


Intéressons-noüs AGhc à à la programmation de ces 


six évÉ ents majeurs, dont chacun peut se pro- 


d | sie au cours du voyage. Nous disons 
eurs », parce qu’ils sont bien plus Toi urd$" 


introduits dans notre programme.,L’un d’eux 


”_sera sélectionné au hasard, au début de chaque 


semaine, sauf si, bien sûr, il s’est déjà produit 

auparavant : dans ce Cas, il ne se passera rigou: 
reusement rien. 

ligne 49 permet de DIMensionner le tableau 

» qui servira de drapeau en signalant si Pun 


4 Je de six x scénarios a’été choisi une première fois. 


ré 
U % 
\' 7 t 
7 - 
de. 
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On passe au sous- -programme de la ligne 6500, 
qui procède à un tir au sort à partir d’un 
GOSUB du programme principal (ligne 870). La 
ligne 6508 détermine un nombre aléatoire com- 


pris entre {| et 10. Comme il y a six événements N; & Te agé ligne 6568si ce n 


possibles, il y a donc 60 % de chances que l’un 
d’eux soit sélectionné. Si, par contre, 7, 8, 9 ou 
10 sont choisis, il ne se passera rien. On peut 


départ, de façon à accroître ou à diminuer les 


Un Si, par exemple, on réécrit la ligne 
façon suivante : 


X=INTIRND(1)*8) +1 


| les chances d’avoir affaire à un événement majeur 
passent 8, c ’est- à-dire à 75 %. Toutefois, 
il faut tenir compté dufait qu’une fois que l’un. 


TRS faire LL Æ à l'épidémie. 


vous les prenez à bord. Vous devrez voyager deux 
jours de plus, et.nourrir quatre personnes sup- 
plémentaires ; mais elles représentent aussi qua- 


+ paires de bras, ce qui pourrait être très utile. 


i votre équipage avait connu des pertes. Le pro- 
gramme vérifie d’abord si l’événement.s’estidéjà 


produit (en s’assurant que le pi élément du. 


tableau MCI n’est pas égal à 1, ligne 6535). Dans 
ce cas, il revient au programme principal, sans 
rien faire d’autres 

Si, par cottre, il a pour valeur zéro, M) est 
mis à 1 par la ligne 6540, de façon qu’il ne 
puisse plus survenir. Cette procédure est respec- 
lée pour chaque événement majeur. 

La ligne 6576. demande au joueur s’il veut ou 
non sauver les naufragés. La ligne 6580 vérifie 
qué le premier caractère de la nse est 0 ou 
n’est pas le cas, 
et la question est posée de nouveau. Si la réponse 
est non, le canôt est bientôt perdu devue, et l’on 
en revient aux affaires courantes. Si la com pas- 


sion l’emporte, le programme prend toutefois des 
il voit d’abord s’il y ade’la place. 


précautions : 
sur votre navire, en vérifiant, ligne 6625, que CN 
(la variable-qui décompte tous les membres 
d’équipage encore en activité) est bien égal à 16. 
Le sauvetage ne sera donc pas possible, et le 
contrôle repasse au programme principal. Ia 
ligne 6630 s’assure ensuite que vous pouvez 
accueillir les survivants : X est fixéà 16 moins CN. 


d’eux a été choisi, ce qui a entraîné la création | Il s’ensuit que X doit être plus grand que 3 pour 


du drapeau correspondant au sein du tableau 
MI}, la probabilité de sélection d’un des cinq 
autres événements tombe à 5 sur 8, soit 62,5 %o. 
Pour un troisième, on passe à 4 sur 8, Soit 50 %, 
et ainsi de suite. Plus il se produit de choses, 
moins il risque de s’en produire davantage:.. 
C’est l'instruction ON X GOSUB qui assure 
PK aiguillage » du programme. Elle est utilisée 
à peuprès de la même façon que ON XGOTO, qui 
Semen, dr mr mineurs. Si X, le nom- 


bre aléatoire, est.égal à 1, on passe au premier 
des numéros de as spécs après l’instruc- : 


tion elle-même. Ce sera i pe 
6530 qui vous fait croiser un cano sauvetage 
Si X est égal à 2, le sous-programme de la Ter 
6700 (la maladie mortelle) est parcouru. Nous 
nous en tiendrons là pour cette fois, mais à l’ave- 
nir nous devrons ajouter, ligne 6510, les quatre 
adresses restantes. 

Dans le premier sous-programme, vous aper- 
cevez à travers votre télescope un canot de 
sauvetage à bord duquel se trouvent quatre hom- 
mes et un grand coffre. C’est à vous de voir si 


La vie à bord 


que les naufragés soient sauvés. Si, par contre, 
X est égal owinférieur à 3, 
informer du fait qu’il ne peut embarquer que 
X hommes supplémentaires, qui seront ‘alors 
intégrés dans La 


à—— de 


Les survivants sont incOrD és dans le tableau 
« catégorie/force», par la boucle qui va de 6638 
à 6697. X a d’abord une valeur initiale de zéro, 
et sert à décomptèr les matelots supplémentaires. 
Le-tableau T$S{, est parcouru pour voir si la caté- 
gorie est égale à zéro, ce qui signifie qu’il y a de 


“en Ja place pour un homme de plus. ue cas de 


X atteint 4, tous les survivants ont é 
sein de votre main-d'œuvre. La a 6655 fixe 
donc à 16 la valeur de T, si bien que le pro- 
gramme quitte la boucle dès qu’il atteint NEXT. 
S’il n’est pas possible de prendre quatre per- 
sonnes de plus, il fait de même après que le & 


le joueur se verra 


McKinnel 


DE SET RU SRE 


tableau a été vérifié à seize reprises. Ceux des res- le programme vérifie évidemment si tout cela ne 

capés qui ont pu monter à bord sont ajoutés à s’est pas déjà produit pendant le jeu, en voyant 

CN, qui tient le décompte des hommes. Chacun si M{2), second élément du tableau MI), n’a pas 

d’eux Se à l’intérieur du tableau TS{), une déjà une valeur de Î : si oui, il repasse en bou- 

à = ; entre lret'5 pour la catégorie, cle principale sans que rien d’autre ne se passe. 

a forc« veaux venus Si l'événement est encore inédit, il faut d’abord 

sont donc en bonne. ou en très “bot santé... constater la présence, ou l’absence, d’un méde- 

- Lecoffre contenait par ailleurs des provisions. ein à bord du navire. C’est pourquoi une boucle 
Une boucle est créée ligne 6685 pour pur de 1 à 16 est créée 

quatre ty de provisions, tandis que la ligne  rie/force contient u 

6690 gén re.un nombre aléatoire compris entre qu’il ; y en aun). S'iln’e déjà mort, sa force 


d’elles. La ligne 6692 affiche ce chiffre, ainsi que valeur de 0. Si X, une fois la 1e ER he 
les unités, gérées par US}, qui représente des. égal à 1, cela signifie qu’il n’y à pas de médec 
_kilos ou des barriques. Si, pendant la semaine, Après quoi, le programme cherche-à save ir “à 
p telle ou telle provision a été épuisée, la ligne 6693 y a des médicaments à bord. Pour cela, il vérifie 
modifie la quantité correspondante de -999 à 0, la valeur de PA(I), l’élément correspondant dans 
pour qu’il soit tenu compte de l’apport, et la ligne le tableau des provisions. Si Ÿ vaut zéro, il‘en 
6694 l’ajoute à ce qui était déjà à bord. A noter existe. Dans le cas contraire, il sera égal à 1. 
aussi que, la répartition des survivants par caté- La ligne 6730 crée un facteur de maladie, Z.:Il 
gories étant faite de façon aléatoire, un navire permet de calculer l’affaiblissement de l’équi- : 
privé de médecin peut bénéficier de la présence page. Z est en effet égal à (X+Y)'10)+5). X et Ysont 
d’un docteur à bord du canot de sauvetage. bien sûr fonction de la présence, ou de l’absence, 


4 ne de médecin et de remèdes. La force sera donc 


La este réduitende 25 si ces deux éléments sont man-- 

P tin à quants, de 15 si un seul manque, de 5 s’ils sont 

Le second événement majeur n’est autre qu’une tous deux. ésents. Les lignes 6734 et 6736 pré-. 
Ssents : 


épidémie de peste, appelée ligne 6700 par le cisentau joueur les raisons de la sévérité de l’épi- 
second numéro de ligne de l'instruction ON X. démie, et vérifient la présence du mé eci 

GOSUB. L'impact de la maladie sera déterminé ‘remèdes en se servant des valeurs de 
par deux facteurs : y a-t-il ou non un médecin : définies précédemment. 2 SN 

_à bord, geerrou a la pricautien d'ach Si are opbres d'équipage ER) dé è 


des flacon: e mé men: g 


Tout c comme pour Je sags-programme précédent, Le maladie es tuerait. X est mis à zéro et utilisé 
pour décompter les morts. Une boucle allant des 

td lignes 6755 à 6775 parcourt le tableau « catégo- 

Fe rie/force » et réduit les forces de ceux qui sont 

& & | touchés; en effet, tous les matelots ne sont pas 

atteints. La ligne 6756 génère un nombre aléa- 

toire. S’il est inférieur à 0.3, la force du membre 


à 
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Programmation 
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d’équipage correspondant dans le tableau ne sera 
pas affectée par la maladie. Chaque homme a 
donc environ 30 % de chances d’échapper à l’épi- 
démie : vous pourrez, si vous le désirez, modi- 
fier ce facteur ou lui donner à lui aussi une valeur 
aléatoire. La ligne suivante s’assure que le marin 
en question n’est pas déjà mort. S’il vit encore, 
sa force est réduite de Z unités. Il se peut que 
cela le tue, en la faisant descendre au-dessous de 
zéro. Une procédure de vérification la remet à 
-99. Lors du relevé hebdomadaire, elle sera 
extraite par le programme qui procédera aux 
modifications nécessaires. X, le nombre d’hom- 


Module huit : 
Deux événements majeurs 


Dimension tableau-drapeau 


49 DIMMCE):REM INDICATEURS POUR SAVOIR SI EVENEMENTS MAJELIRS 
DEJA SURVENUS 


Addition à boucle principale 


878 GOSUBESOD:REM EVENEMENTS MAJEURS 


SIP sélection événements majeurs 


ESDQ REM EVENEMENTS MAJEURS 
ESSS X=INT CRNDC1) #10) +1 
6512 ON X GOSUB6530, 6700 
6S20 RETURN 


SIP événements majeurs 


REM CANOT SAUVETAGE 

1FMC1)=1THENRE TURN 

PRINTCHR#(147) 

MC1)=1 

S$="UN CANDT DE SAUVETAGE+" : GOSUB9 120 
Ss="APPARAIT AU LOIN*":GOSUBS100 
PRINT : GOSUB3200 

S$="AU TELESCOPE VOUS VOYEZ+*":GOSUB9100 
Ss$="QU" IL CONTIENT*" : GOSUBS31 28 
PRINT : GOSUB9320@ 

Sé="4 PERSONNES*" : GOSUB91 00 

GOSUB3200 

S#="ET UN GRAND COFFRE !#":GOSUBS10@ 
PRINT : GOSUBS200 

S$="EN CHANGEANT DE CAP+":GOSUBS100 
S$="POUR LES SAUVER+" : GOSUBS 100 
S$="VOUS PERDREZ DEUX JOURS. +" :GOSUB91 


PRINT : GOSUB3200 
Ss="VOULEZ-VOUS LES SAUVER CO/N) ?*":GOSUB 


INPUTI#: ISmLEFTSCI6, 1) 

IF1#<2"o"ANDIS < >"N"THENES78 

IF1$="0" THENGEOO 

PRINT : GOSUB9200 

S$="LE CANOT DISPARAIT AU LOIN...#:G0SUB93100 
PRINT : G0SUB93208 

Ss=K$ : GOSUBS100 

GETIS:1F1$=""THENGSS6 

RETURN 

PRINT :G0OSUB3200 

EW=EW+2/7 

IFCN<)15 THENEB30 

S#="VOUS NE POUVEZ LES SAUVER+" :GO0SUB9100 
St="PAR MANQUE DE PLACE SUR LE BATEAU*" : GOSUB9 120 


X=16-CN:IFX)3 THENGESS 
S#="VOUS N'AVEZ DE PLACE QUE POUR«":GOSUB3100 
PRINT: "PERSONNES DE PLUS*" 
PRINT :GOSUB3200 
S$="VOUS SAUVEZ:#+":GOSUB910@ 
x=0 
FORT=1T016 
IFTSCT, 1)<> OTHEN6E79 
X=X+1 
IFX>4THENT=16: GOTO6679 
CNeCN+1 
TSCT: 1) =INTCRND(1)#S) +1 
TSCT, 2) = INT CRND(1) #50) +50 
PRINT"1 “#CSCTSCT, 1)) 
6679 NEXT 
6680 PRINT :G60SUB3200 
6682 S$="LE COFFRE CONTIENT:*+": GOSUBS1 00 
6685 FORT=1TO4 


mes tués par la peste, sera ainsi incrémenté de 1. 
Si d’aventure il y avait des remèdes (ce qui est 
indiqué par Y-(), la ligne 6776 en divise la quan- 
tité par deux et arrondit le résultat de façon à 
obtenir un nombre entier de bouteilles. Il se peut 
aussi que personne ne soit mort (X-0); dans ce 
cas, on revient à la boucle principale. Dans le cas 
contraire, le joueur apprendra combien de ses 
hommes ont péri. 

Dans le module suivant, nous verrons quelques- 
uns des autres événements majeurs qui peuvent 
survenir au cours de la traversée, notamment de 
sérieux problèmes avec le gouvernail. 


X= INT CRND( 12 #10) +1@ 
PRINTXIUSCT):"S DE" 5PSCT) 
IFPACT)=-SS9STHENPACT) =@ 
PACT)=PACT)+X 
NEXT 
GOTOES92 
REM EPIDEMIE DE PESTE 
IFMC2)=1 THENRETURN 
PRINTCHRS#(147) 
6718 MC2)=1 
6712 S$="LA PESTE FRAPPE !#":GO0SUB9100 
6714 PRINT :G0SUB3200 
6716 X=1 
6718 FORT=1T016 
6720 IFTSCT, 1)=2ANDTSUT, 23< > DANDTSCT, 2)< > -S9STHENX 
=O:T=16 
6722 NEXT 
Y=1 
IFDA( 12< > BANDOA( 1) < > -SSSTHENY=® 
T=CX4+Y)#10) +5 
1S="VOUS AVEZ" : IF X=2DANDY=@THENS748 
IFX=1THENSS="ET PAS DE MEDECIN*":GOSUB9100:1#="A 
No“ 
6736 IFY=1THEN S$=16+"PAS DE REMEDES*" : GOSUB9100 
6740 S$="BEAUCOUF DE MATELOTS SONT ATTEINTS":GOSUBS12@ 
PRINT : GOSUBS200 
x=@ 
FORT=1TO16 
IFRND (1) <. STHENE775S 
6760 IFTSIT, 2) =GORTSCT, 2) =-99STHENE775 
6765 TSCT, 2)=TSCT, 2)-Z 
6770 IFTSCT, 2)€ 1THENTS(T, 2)=-999:X=X+1 
6775 NEXT 
6776 IFY=1THENS780 
6777 Sé="1/2 DE VOS REMEDES ONT SERVI*+":GO0SUBS100 
6778 DAC1)=INT((DA(1)/2)+. 5) 
6780 PRINT :G0SUB9200 
6785 IFX=OTHENE797 
6790 PRINT "ET":X: 
6792 S$="MEMBRES D’ EQUIPAGE MEURENT#" 
6794 IFX=1THENSS="MEMBRE D'EQUIPAGE MEURT #" 
6735 GO0SUB3108 
6736 PRINT :GOSUBS3200 
6797 S$=K$:G0SUB9120 
6798 GETIS:1IF1$=""THENS798 
6799 RETURN 


Variantes de basic 


Spectrum : 
Procédez aux changements suivants : 


6510 IFX=1 THEN GOSUB 6530 

6b11 IFX=2 THEN GOSUB 6700 

6536 CLS 

6578 INPUT $ : LET I$ (1 TO 1) 

6596 LET 1$ = INKEYS : IF I$ = “ "THEN GOTO 65% 
6706 CLS 

6798 LET 1$ = INKEYS : IF 1$ = “ "THEN GOTO 6798 


BBC Micro : 
Procédez aux changements suivants : 


6536 CLS 
6596 1$=GETS 
6706 CLS 
6798 1$=GETS 


| 


Les différences d’architecture entre les micros, impliquent des 
différences d’écriture des programmes de contrôle du bras de robot. 


Nous traitons ici du Commodore. 


Leur séquence est de 1/60° de seconde. Le programme en code 
machine du Commodore intercepte le vecteur d’interruption 
et exécute sa propre routine, avant de donner le contrôle à 
la routine normale d’interruption. Ce programme est appelé 
« intercalaire ». La première partie du code machine concerne 
donc le remplacement du vecteur normal [RQ par le vecteur 
de la routine qui nous intéresse. 

Après cela, le programme-contrôle prédéfini d'événement 
sera implémenté à chaque occurrence d’une interruption lRQ. 
Le code de contrôle de l’événement est pour sa part très sem- 
blable au programme de contrôle multiserveur. La routine en 
code machine reçoit l’information qui détermine la durée des 
impulsions moteur à partir d’une table à 8 octets, appelée 
ANGLE. 

Du code supplémentaire sert à charger les positions pour 
ANGLE à partir d’une deuxième table, NOUVPOS, chargée à par- 
tir du programme de contrôle BASIC. Le programmateur de 
la séquence du bras utilise ce programme en code machine 


Erratum 


Le diagramme de 
disposition de la carte 


pour piloter le bras du robot. Il permet de diriger le bras à 
partir du clavier et de sauvegarder les positions clés, suscep- 
tibles d’être reprises par le bras ou stockées sur disque ou sur 
bande. Néanmoins, il faut tenir compte de deux éléments 
importants avec le Commodore 64 : d’abord, lors de la 
conduite du bras, les moteurs ont tendance à osciller. Cela 
est dû à l’interférence en provenance du composant vidéo 
VIC-IT, avec l’émission normale d’interruptions. La manière 
la plus simple d’y remédier est de vider l’écran lors de l’utili- 
sation du programme intercalaire. 

Le deuxième problème vient de la lenteur du BASIC Commo- 
dore à lire la frappe au clavier (et à effectuer les connexions 
appropriées). Le sous-programme final en code machine est 
donc utilisé pour comparer les codes ASCII lus au clavier aux 
valeurs d’une table représentant les touches significatives. 
Lorsqu'une correspondance est établie, la valeur est transmise 
sous la forme d’un nombre pouvant être utilisé par l’instruc- 
tion BASIC ON..GOSUB pour appeler la routine appropriée. 


Programmeur de séquence 
de bras/Commodore 64 


0000000 
000 o 9 0 o LOI) 
QIGAAOIOPIORIO 
AM 

Q 


interface Spectrum donné 
précédemment comporte 
des erreurs. Voici les 
modifications à apporter : 
le long fil volant doit être 
reporté un trou plus à 
droite sur son extrémité 
droite, tout comme à 
l'extrémité gauche de la 
liaison adjacente. Le seul 
pontage de la deuxième 
rangée doit être déplacé 
d'une position sur la 
droite. L'extrémité droite 
de la courte liaison à la 
gauche de la deuxième 
rangée devrait être deux 
trous plus à droite. 
Notez également 

les modifications 
correspondantes sur le 
bord de cuivre de 

la carte. 

(CI. Kevin Jones.) 


Chargeur basic 


19 
20 


REM 
REM 
REM 
REM 
REM 
REM 


FOR 


ee ee ee 
C2 ++ 
“+ CHARGEUR BASIC POUR + 
#** LE CONTROLE DE BRAS CEM ## 
+ + 


ete eee ee ee 


1=49155S TO 49394 


RERD A:POKE I, A: CC=CC+A 
NEXT 1! 


READ CS:1F CS<>CC THEN PRINT "ERREUR DE PARITE":STOP 


DATA16S, 255, 141, 3, 221, 169,62, 141,1 
DATA1S2, 169, 192, 141, 2, 192, 120, 173 
DATA20, 3, 174, 1, 192, 141, 1, 192, 142 
DATA20, Z, 173, 21, 3, 174,2, 192, 141,2 
DATA192, 142, 21, 3, 169, 16, 133, 251 
DATALSS, 193, 133, 252, 169, 255, 160, @ 
DATA145, 251, 136, 206, 251,88, 96, 8, 72 
DATA1S2, 72, 138, 72, 169, 255, 141; 1 
DATA221, 162, 7, 169, 255, 24, 106, 72 
DATR188, @, 195, 49, 251, 145, 251, 104 
DATA202, 16, 243, 160, 48, 136, 208, 253 
DATA1ES, 255, 160, @, 49, 251, 141, 1, 221 
DATA200, 208, 248, 162, 7, 159, 255, 188 
DATA, 193, 145, 251, 202, 16, 248, 184 
DATA170, 184, 168, 104, 49, 198, 1, 192 
DATA162, @, 160, @, 189, 8, 197, 221,0 
DATA19S, 240, 14, 176, 6, 222, @, 193, 76 
DATA1SE, 192, 254, D, 195, 76, 156, 192 
DATA200, 252, 224, 4, 208, 228, 32, 169 
DATA192, 192, 4, 208, 217, 96, 138, 72 
DATA1S2, 72, 160, 255, 174, @, 192, 136 
DATA234, 2354, 208, 251, 202, 208, 248 
DATA1G4, 168, 104, 170, 96, @, 255, 255, @ 
DATAG, 255, 255, O, ©, 255, 255, @, @, 255 
DATAZSS, ©, ©, 72, 138, 72, 152, 72, 32 
DATAZ28, 255, 201,0, 240, 249, 162,0 
DATAZ21, 191, 192, 240, 7, 232, 224,17 
DATA208, 246, 162, 255, 142, 207, 192 
DATA1B4, 168, 194, 170, 104, 9% 
DATASS50937:REM CONTROLE DE PARITE*# 
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Listage d'assemblage 


Dttttttttttitthtththttettththtté 
Fhttttitththtthththtttthttt 
++ ++ 
+ CBM ARM CONTROLLER ++ 
+ ++ 
tttttththhthtthththtthtthttttt 
tttttttthttthttttttthtttttt 


PORT = 56577 USER PORT DATA REGISTER 
DDR=5657S 2USER PORT DATA DIRN REG 
ANGLE =$C 108 ANGLE VALUE LOCATION 
NEUPOS=$#C198 :POSITION TABLE 
MOTTAB=#C11Q :MOTOR LOOK UP TABLE 
ZPAGE=$FB :@ PAGE POINTER TO TABLE 
IRGQVEC=#0314 ; IRQ VECTOR LOBYTE 


$c22a 
DELFAC *x=4x+1 :STORAGE FOR DELAY FACTOR 
OUPVEC x=#+2 STORAGE FOR OUR VECTOR 


LOA #SFF 

STA DDR #SET ODR TO OUTPUT 
LDA #<EVENT 

STA QURVEC #POINT TQ EVENT 


LOA H)DEVENT  : HANDLER 
STA QURVEC+I 


SEI # INTERRUPTS OFF 
LOA IRQGYEC :SUWUAP EXISTING 
LOX QURVEC :1IRQ VECTOR FOR 
STA OURVEC OUR VECTOR 

STX IRQVEC 

LDOA IRQUEC+1 

LOX OURVEC+I 

STA OQURVEC#+1 

STX IRQVEC+I 


2++t++ INITIALISE TABLE ++++ 


LOA #<MOTTAB 
STA ZPAGE 
LOA #>MOTTAB 
STA ZPAGE +1 


LOA #S$FF 

LDY #$29 
TABLE 

STA (ZPAGE),Y 


BNE TABLE 
CLI 3 INTERRUPTS ON 


+++ EVENT HANOLER ++++ 


VENT 
PHP 
PHA ISAVE REGISTERS 
TrA 30N-STACK 


) PHA 
TXA 


lan McKinnell 


PHA 


+ START PULSE, FOR SOME MOTORS IT 
2MAY BE POSSIBLE TO START BEFORE FILLINGS 
: TABLE AND SO REDOUCE WAIT LOOP BELOW ++ 
3 
LOA #SFF 
STA PORT 
1++ FILL TABLE WITH EXCEPTIONS ++ 
LDX ##27 
LOA #S$FF 
CLC 
EXCEPT 
ROR À 
PHA #BIT PATTERN 
LOY ANGLE ,X :GET MOTOR X OFFSET 
AND (ZPAGE),Y :KEEP EXISTING PATTERN 
STA (ZPAGE),Y :BUT MODIFIED FOR MOTOR X 
PLA 
DEX 
BPL EXCEPT 
3++ TABLE IS NOW LOADED ++ 
LOY #$30 
LAIT 
DEY :FILL IN SOME 
BNE WAIT 2 TIME 
LOA #S$FF ALL PULSES ON 
LOY #s22 


LOOP 
ANQO (ZPAGE),Y :BUT MASK OFF WITH EACH 
STA PORT TABLE ELEMENT IN TURN 
INY 
BNE LOOP 


LOX ##$a7 
LDRÀ #S$FF 
CLEAR 
LDY ANGLE ,X 
STA (ZPAGE),Y 
DEX 
BPL CLEAR 
++ ALL PULSES SHOULD NOW BE FINISHED ++ 
PLA 
TAX 
PLA ?RESTORE REGISTERS 
TAY 
PLA 
PLP 
JMP (OURVEC) 


2CLEAR ALL EXCEPTIONS 


3JUMP TO NORMAL 
#1RQ ROUTINE 
; 
1++++ SMOOTH SERVO MOVER ++++ 
: 
LOOPe 
LDX*X #s20 
LOY #$20 
LAOP 1 


LOA NEWPOS,X :NEW POSN FOR SERVO X 
CMP ANGLE,X :1S OLD POSN SAME? 
BEQ MQVED. 21F = THEN O0 NOTHING 
BCS ADD 31F > THEN ADD 
DEC ANGLE,X :ELSE SUBTRACT 
JP INCRX 

ADO 
INC ANGLE ,X 
JMP INCRX 

MOVED 


INCRX 

CPX ##a4 #ALL 4 SERVOS OONE 
BNE LOOP1 31F NOT NEXT SERVO 
JSR WAITER *SHORT PAUSE 


CPY #s24 3IF Y=4 THEN ALL MOVED 
BNE LOOPe 


PHA FISAVE X & Y REGS 


LOY #SFF 
LDX DELFAC GET DELAY FACTOR 


NOP 1256*8 CLOCK CYCLES 
NOP #WAIT 

BNE ENCORE 

DEX 3 IF MORE DELAY THEN 
BNE ENCORE ?REPEAT 


TAX 
RTS 
; 
5+++t+ CHECK KEYBOARD ++++ 
3 
KEYTAB x=4+16 
RESULT *x=x+1 
GETIN=S$FFE4 
; 
CHECK 


JISR GETIN GET À CHAR 
CMP #S00 NO CHAR? 
BEQ NOKEY 

LDX ##02 


CMP KEYTAB,X 


BEQG EXIT ?1S CHAR IN TABLE? 


CPX #17 


BNE COMPAR 
LOX #SFF #SIGNAL NOT FOUND 


EXIT 
STX RESULT STORE KEYTAB OFFSET 


PLA 


Programmateur séquences bras 


REM 

REM 

REM #4 

REM «+ 

REM ++ SÉQUENCES BRAS **+ 
REM ++ 

REM 

REM 

: 


ON=8:REM FOR CASS ON=1 

IF A=@ THEN A=1:LORD"BRAROB, HEX"ACTIVE 1 

180 GOSUB 1000:REM ACTIVER 

119 PRINT CL$ 

128 X=5:Y=6:GOSUB12000: PRINT VOUDRIEZ-VOUS : * 

138 X=4:Y=10:GOSUB18008: PRINT"1....NOUVELLE SEQUENCE BRAS DE 
PROGRAMME * 

148 X=4:Y=12:G0SUB10088: PRINT"2.... AJOUTER DEPLACEMENTS À UN 
PROGRAMME * 

150 X=4:Y=14:GOSUB18000: PRINT“3,...EXECUTER À NOUVEAU UN 
FICHIER* 

168 X=4:Y=16:GO0OSUB18080: PRINT "4. 
179 GET G$:1F G$="" THEN 178 
180 1F G$="1" THEN C=0:LM=@:REM RESTAURER TABLEAU PTRS 
190 1F G$="1" OR G$="26 THEN GOSUB2000:GOSUBS000:G 
: GOSUBS200 

IF G$="3" THEN GOSUB6006: GOSUB4800 

IF G$="4" THEN PRINTCL#:END 

GOTO 118 

REM wwws FONCTIONS CLEFS sen 

DX=DX+1 : RETURN 

DX=DX-1:1F DX<@ THEN DX=@ 

RETURN 

P=PEEK(NP)+DX:1F P<2S6ETHEN POKENP, P 

RETURN 

P=PEEKÇCNP)-DX:1F P>OTHEN POKENP, P 

RETURN 

P=PEEK(NP+1)+DX:1F P<2S6STHEN POKENP+1; P 

RETURN 

P=PEEKCNP+1)-DX:1F P>@THEN POKENP+1,P 

RETURN 

P=PEEK(NP+2)-DX:1F P>@THEN POKENP+2, P 
P=PEEKÇ(NP+2)+DX:1F P<2S6THEN POKENP+2, P 

RETURN 

P=PEEK(NP+3)+34DX:1F P<2SBTHEN POKENP+3, P 
RETURN 

PePEEK(NP+3)-SeDX:1F FR 2SSTHEN POKENP+3, P 
RETURN 

FOR 1=@ TO 3:POKE NP+1, RXCC, 1) :NEXT I: RETURN 
C=C+1:1F C)MC THEN C=@ 

RETURN 

C=C-1:1F CC@ THEN C=MC 

RETURN 

FOR 1=8 TO 3:RX(C, 1) =PEEK(NP+1) 3NEXT:C=C+1:RET 


SRBSSISSSSS 


QUITTER LE PROGRAMME" 


N 
e 


1 


SASHSISREUBESS 


1 


nana 
Sa 


FOR 1=@ TO 3:RX(C, 1) =PEEK(NP+1) :NEXT:C=C+#1 : RET 


#S85366RSERE 


: 
1008 REM eus ACTIVER mn 

@ C=B:NS=8:REM NO. OF DEPLACEMENTS-1 

1020 LM=@:0C=0:DF=18:REM FACTEUR DE RETARDEMENT 

1030 MC=10G:REM COMPTE MAX 

1848 DIM RXC(MC, NS):REM CPE TABLEAU POSITIONS 

1950 CL$=CHR$(147) :REM VIDER L'ECRAN 

1060 DWS=""1:FOR I=1 TO 25:DWS=DW#+CHRS#C17):NEXT 13 

REM CURSEUR BAISSE 

1065 POKE 650, 128:REM ACTIVER LES TOUCHES POUR REPETITION 
1070 OL=49152:NP=4S416:REM RETARDER ET POSITIONNER LES 
ADRESSES 

1075 GS=491S5S:0FF=49170:REM INTERCALAIRE ON/0F/ ADRESSES SYST. 
1077 MOVE=49281:REM DEPLACER LES ADRESSES SYSTEME DES SERVOS 
1078 KEYTAB=49%4%:RESUL T=49359:REM ADRESSES DES TOUCHES 

1979 CHECK=4S36G:REM ADRESSE SYSTEME DE VERIFICATION DE TOUCHE 
1080 REM ** LIRE DONNEES ASCII TOUCHES *» 

1990 FOR 1=@ TO 14:READ A:POKE KEYTAB+I, A:NEXT I 

1108 DATA 73,69, 157, 29, 145, 17, 65, 90, 88, 67 

1118 DATA 82, 78,66, 85, 81 

1280 REM #** AUCUNE POSITION NOUVELLE #* 

1218 FOR 1=@ TO 3:POKENP+1,@:NEXT I 

1990 RETURN 

1999 : 

2008 REM we INFORM sr 

2818 PRINTCLS 

2020 X=5:Y=5:GOSUB18000:PRINT"PLEASE USE :" 

2038 X=1:Y=7: GOSUB10080: PRINT"TOUCHES-CURSEURS. .. POUR G/D ET 
H/B 1ER BRAS 

2048 X=1:Y=9:GOSUB1D000:PRINT"'A 8 Z.........FOR 2N 


D ARM H/B" 
2050 X=1:Y=11:G0SUB10000: PRINT"X & C.........FOR 2e BRAS 


RAB"OUVERT/FERME" 

2060 X=1:Y=13:GOSUB10000: PRINT"S......,,.....POUR SAUVEGARDER 
UNE POSITION 

2070 X=1:Y=15:G0SUB10000: PRINT "Q. «POUR REVENIR AU 
MENU 


2080 X=1:Y=17:GOSUB10000: PRINT"R. . 
UNE POSITION SAUVEGARDEE 

2090 X=1:Y=19:GOSUB10000: PRINT'N & B.........SUIVANT ET COMPTE 
ARRIERE 

2188 X=1:Y=21:GOSUB100BB: PRINT"E. ............AFFECTER NOUVEAU 
COMPTE 

2118 X=1:Y=23:00SUB10000: PRINT"I & D... 
LA VITESSE 

2128 X=2:Y=2:GO0SUB10008: PRINT "COUNT=" CI" 3 

2130 FOR I=0 TO S:PRINTRX(C, 135" "3 2NEXT2 PRINT 

2135 GET AS:IF Aé="" THEN 2135 

2148 RETURN 

2399 : 

J008 REM ser PROGRAMME BRAS ste 

3005 GOSUB7000:REM VIDER L'ECRAN ET COMMENCER PROG. 
INTERCALAIRE 

3910 POKE OL,1:REM METTRE FACTEUR DE RETARDEMENT À 1 

3020 DX=B:REM MODIFIER CADENCE 

Ta3@ SYS CHECK:REM VERIFIER SAISIE 

TOSS R=PEEK(RESULT)+11F R>15 THEN S@SG:REM FRAPPE ILLEGALE 
3837 ON R GOSUB 540,550, 560, 570, 580. 590, 600, 610, 62 

©. 630, 640, 650, 660, 670 

3190 1F C)LM THEN LM=C-13REM RECORD COMPTE MAX JUSQU’ ICI 
3228 OC=C 

3260 SYS MOVE:REM M/C DEPLACER LES SERVOS 

3278 IF P=15 OR C)MC THEN GOSUBB@OB:RETURN:REM DESACTIVER 
LE PROG. INTERCALAIRE ET TERMINER 

3288 GOTO SOSG:REM REPETE 

3999 : 

400G REM ww REFAIRE UNE SEQUENCE ser 

4818 PRINTELS 

4028 X=5:Y=23:GOSUB1DO0G: PRINT REFAIRE UNE SEQUENCE O/N, 

R REPETE" 

4@SD GET ANS:IF ANS<>"D" AND ANS<>"N" AND ANS<>"R" 

THEN 4030 

4840 IF ANS="N" THEN RETURN 

4858 IF ANS<)"R" THEN X=5:Y=22:G0SUB1 2000: INPUT"FACTEUR DE 
RETARDEMENT 1-255" 5DF 

4060 IF<DF @ OR DF>255 THEN 40SG:REM VERIFIER ECHELLE 
4078 POKE DL, DF:REM AFFECTER LE REGISTRE DU FACTEUR DE 
RETARDEMENT 

4075 GOSUB7000:REM VIDER L'ECRAN ET COMMENCEZ LE PROGRAMME 
INTERCALAIRE 

4880 FOR I=@ TO LM 

4098 X=5:Y=2:G0SUB12000: PRINT"NO. IN SEQUENCE = “; 

à 4 bte | 

4188 FOR S=@ TO 3 

4118 POKE NP+5 RCI: 5) 

4128 NEXT S:SYS HOVE:REM M/C DEPLACER SERVOS 

4120 NEXT 1 

4135 GOSUBSOQO:REM RESTAURER L'ECRAN ET DESACTIVER PROGRAMME 


+ POUR ALLER SUR 


+ POUR INC. ET DEC. 


S018 PRINTCLS 
S020 x=5:Y=19:GOSUB10000: PRINT SAUVEGARDER SUR FICHIER UNE 
SEQUENCE O/N 
SOS GET AN$:IF ANS<>"o" AND AN$<2"N" THEN SO38 
S040 IF ANS="N" THEN RETURN 
X=5:Y=12:G0SUB10000: INPUT"NOMBRE FICHIER" :FLS 
OPEN 3, DN, 3, “Q@:"+FL#+", DATA, S, W":REM OPEN FI 


FOR A=8 TO LM:FOR B=8 TO 3 
PRINT#S, RXCA, BD2NEXT B, A 
5100 PRINT43:CLOSES 

28 RETURN 

5998 : 
GO0S REM ++ CHARGER UN FICHIER sen 

6912 PRINTCLS 

6828 X=5:Y=10:60SUB12008: INPUT NOM DU FICHIER À CHARGER*“:F 


sese 

soc 

LE 

5070 PRINTHS, LM 
sese 

soso 


6049 OPEN 3, ON, 3, "O0: "+FL#+". DATA, S, R"2REM OUVRIR FICHIER 
6258 INPUTHS, C:LM=C 
6060 FOR A=@ TO C:FOR B=@ TO 3 
6078 INPUTHS, RX(A, B):NEXT B,A 
6282 PRINTH3:CLOSES 

6198 RETURN 

: 

REM #wr COMMENCER INTERCALAIRE mme 

7018 POKES326S, PEEK(S53265) AND 239:REM VIDER ECRAN 


7815 SYS GS 
7028 RETURN 

793939 : 

SO0Q REM wwws FIN INTERCALAIRE #ntn 

8918 POKES326S, PEEK(S326S)0R 15:REM VIDER ECRAN 
8015 SYS OFF 

8028 RETURN 

8339 : 

10008 REM swe* POSITIONNER CURSEUR EN X; Y #mm 

10019 PRINTCHRSC19) 3 : PRINTTAB(X) :LEFTS(DHS, V2 3 

10020 RETURN 
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Ru Langage machine 
Effets visuels 


Considérons la puce contrôleur vidéo du Commodore 64 — VIC:II — 
pour voir comment on peut utiliser ses registres afin d’afficher 
différents modes et des effets visuels inhabituels. 


Tableau 1 


Il existe huit modes graphiques de base sur l’écran 
du Commodore 64. En graphique basse résolu- 
tion, le jeu de caractères peut se trouver en ROM 
ou en RAM, et être affiché dans l’un des trois 
modes possibles : le mode standard, le mode mul- 
ticolore ou le mode couleur étendu. Il existe aussi 
deux modes haute résolution : standard et mul- 
ticolore. De plus, il peut y avoir de nombreuses 
variantes : on peut régler l’écran pour 38 colonnes, 
au lieu des 40 habituelles, et/ou 24 lignes, au lieu 
de 25. Ce mode est normalement utilisé conjoin- 
tement avec le défilement vertical ou horizontal. 
Les caractéristiques de défilement du C64 sont 
le mieux exécutées à partir du langage machine, 
puisque les données d’affichage doivent être 
décalées assez rapidement en RAM écran. 

Si l’on utilise un écran haute résolution en 
même temps qu’un long programme, alors la 
mémoire peut faire prime. Le C64 autorise une 
liberté considérable dans l’emplacement des 
écrans haute et basse résolution, et nous commen- 
cerons donc par examiner comment le program- 
meur peut les déplacer tous deux en mémoire. 
Comme nous le verrons plus loin, si l’on utilise 
le langage machine pour le tracé, il est même pos- 
sible de placer l’écran haute résolution derrière 
la ROM interpréteur BASIC. C’est très important, 
car, si l’on exécute seulement le langage machine, 
l’interpréteur ROM prendra 8 K d’espace mé- 
moire valable qui ne servent à rien! Par une 
coïncidence intéressante, ce sont exactement 8 K 
dont nous avons besoin pour un écran haute 
résolution. 

La fonction de la puce d’interface vidéo 
6566/67 (VIC-II) est de générer les données 
d’affichage vidéo, qui sont transmises à la télé- 
vision ou au moniteur. Pour faire cela, VIC-II 


doit être capable de lire des données de la RAM 
ou de la ROM. Il est bon de comprendre com- 
ment VIC-II obtient ses données, puisque cela 
détermine l’un des aspects les plus obscurs du 
Commodore 64. 


Mode multicolore 


Nous avons décrit précédemment le mode d’affi- 
chage basse résolution normal et la table 
d’implantation de bits. Ici, nous examinerons 
deux des autres façons dont on peut utiliser les 
graphiques machine. 

En mode multicolore, il est possible d’avoir 
quatre couleurs dans une seule cellule de carac- 
tère, au lieu de deux. Mais le prix à payer est que 
la résolution horizontale est maintenant en 
paires de pixels au lieu de pixels uniques. Le mode 
multicolore peut être employé en graphique haute 
ou basse résolution, bien que les couleurs des 
points soient déterminées un peu différemment 
dans le mode haute résolution. Les POKEs sui- 
vants à partir du BASIC valident ou invalident le 
mode multicolore : 


POKE 53270,PEEK(53270)0R16 
POKE 53270,PEEK(53270)AND239 


En mode basse résolution, quand le mode mul- 
ticolore est mis, si le bit 4 du quartet (c’est-à-dire 
4 bits ou un demi-octet) couleur associé est à 1, 
alors le caractère est interprété en mode multi- 
colore, les 3 bits inférieurs déterminant la cou- 
leur. Cela signifie que ces caractères qui ont asso- 
cié les quartets couleur dans l'intervalle 0 à 7 sont 
interprétés normalement ; si le code couleur se 
trouve entre 8 et 15, alors le caractère sera affi- 
ché en mode multicolore. Les couleurs des 
paires de pixels apparaissent dans le tableau 1. 

En modifiant les contenus des adresses 53282 
et 53283, nous pouvons instantanément changer 
la couleur de toutes les paires de pixels multico- 
lores associées. Il faut noter que le mode multi- 
colore marche mieux avec les caractères définis 


Fond d'écran 
Multicolore#i 
Multicolore#? 
Couleur d’avant-plan 


par l’utilisateur — c’est-à-dire que les configu- 
rations de bits prennent en compte le fait qu’ils 
sont interprétés comme des paires. 

Un autre mode graphique disponible pour le 
programmeur du C64 est le mode couleur étendu. 
Il permet de contrôler la couleur de fond des 
64 premiers caractères dans la matrice caractère. 
Le mode couleur étendu ne peut être utilisé en 
conjonction avec le mode multicolore. Les lignes 
BASIC suivantes valident et invalident respective- 
ment ce mode : 


Tableau 2 


64-127 
128-191 
192-255 
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POKE 53265,PEEK(53265)0R64 
POKE 53265,PEEEK(53265)AND191 


Le même caractère peut apparaître à l’écran avec 
jusqu’à quatre différentes couleurs de fond, dont 
l’une est la couleur du fond d’écran. Les carac- 
tères restants ne peuvent être affichés en mode 
couleur étendu, puisque les bits 6 et 7 du code 
écran servent à contrôler indirectement la cou- 
leur du caractère. Par exemple, le code écran 
pour « À » est |, et celui d’un champ inverse 
« A » est 65. Cependant, si nous faisions POKE 6b 
dans l’écran en mode couleur étendu, nous ne 
verrions pas un champ inverse « À », mais un 
« A » normal avec une couleur de fond détermi- 
née par le contenu de l’adresse 53282 ($D022). De 
même, en faisant POKE 129 dans l’écran, on pro- 
duirait un « À » normal, mais avec une couleur 
de fond déterminée par le contenu de l’adresse 
53283 (50073). Le tableau 2 montre comment 
codes écran et registres couleur sont reliés. 


Organisation mémoire 


La puce VIC-II voit une carte de la mémoire dif- 
férente du 6510, et bien plus simple. A tout ins- 
tant, VIC-II ne peut voir que quatre blocs de 
16 K de mémoire. Nous pouvons assimiler un 
bloc de 16 K à la « fenêtre » de VIC-II sur la 
mémoire. L'adresse de base de cette fenêtre peut 
prendre l’une des quatre valeurs sous contrôle 
logiciel. 


1000 REM** SÉLECTION BLOC POUR FENÊTRE VIC** 

1010 POKE 56578,PEEK(56578)0R3:REM DDR CIA#2 BITS 0,1 EN 
SORTIE 

1020 WD=3:REM SÉLECTIONNE FENÊTRE NORMALE 

1030 POKE 56576, (PEEKI56576)/AND252) OR WD:REM PORT A 
CIA#1 BITS 0,1 


Ici, WD (pour « WinDow » : fenêtre) peut prendre 
des valeurs comprises entre 0 et 3. A tout 
moment, la valeur de WD en cours est trouvée 
par PEEK(56576)AND3. L'adresse correspondante du 
bas de la fenêtre 16 K en mémoire est calculée 
à l’aide de la formule : WB=16384*(3-WD), où la 


valeur de WD donne les adresses correspondantes : 


A l’intérieur de la fenêtre VIC-II, le 6510 s’attend 
à voir la mémoire écran et une image ROM de 
caractère en basse résolution (ou une donnée 
haute résolution si c’est le mode HR qui est sélec- 
tionné). Il peut aussi avoir besoin de trouver des 
données de lutins et, le cas échéant, de voir à 
l’intérieur de la fenêtre. Les pointeurs pour cha- 
cun des huit lutins sont placés à la fin de la 
mémoire écran (et doivent être déplacés avec 
l’écran). 


Langage machine 


Le décalé du début de la mémoire écran à par- 
tir de la base de la fenêtre VIC-II en cours est 
contrôlé par les quatre bits supérieurs du regis- 
tre de contrôle VIC-II à l’adresse 53272 ($D018). 
En utilisant ces quatre bits, nous pouvons 
placer l’écran dans n’importe lequel des blocs de 
16 K à l’intérieur de la fenêtre. 


1040 REM** SÉLECTION DECALÉ ÉCRAN A PARTIR DE BASE 
DE FENÊTRE"** 

1050 SO=1:REM CELA SÉLECTIONNE DECALÉ NORMAL 

1060 POKE 53272 (PEEK(53272)AND15)0R 16*S0 


Ici, S0 peut prendre des valeurs comprises entre 
0 et 15. A tout moment, la valeur de $S0 en cours 
est trouvée à l’aide de PEEK(53272)AND15. L’adresse 
correspondante de la base de l’écran en cours 
dans la mémoire est calculée par l’expression 
SC=WB +1024+S0 (base de fenêtre plus décalée), ou : 


SC=16384"(3- (PEEK(56576)AND3) 
+64" (PEEK(53272)AND240) 


Le problème est que, en déplaçant l’écran, la 
RAM couleur ne se déplace pas. Donc, si nous 
voulons avoir un autre écran, il nous faut une 
petite routine en langage machine pour échanger 
la mémoire couleur avec un tampon de manière 
appropriée. 

Un autre facteur à considérer est que, si vous 
voulez faire PRINT sur le nouvel écran, il est alors 
nécessaire de le dire au système d’exploitation (au 
lieu de la puce vidéo) où se trouve le nouvel écran. 
Cela peut être fait par POKE (ou STA) dans 
l’adresse 648 (50288), qui est un pointeur devant 
soutenir l’octet hi de l’adresse de base de la 
mémoire écran. Si SC est calculé comme ci- 
dessus, le code BASIC suivant fera l’affaire : 


POKE 648,INT(SC/256) 


Pour sélectionner l’adresse de base de la matrice 
caractère ou de l’écran HR, nous utilisons le code 
suivant : 


1070 REM'* SÉLECTION HR/MC DÉCALÉ DE BASE DE 
FENÊTRE** 

1080 HO=4:REM CELA SÉLECTIONNE DÉCALÉ NORMAL 
1090 POKE 53272 (PEEK(53272)AND240)0R 2*HO 


En principe, H0 peut prendre toute valeur com- 
prise entre Üet 7, mais en pratique d’autres fac- 
teurs limitent les options. Avec l’équivalent WD 
à | ou 3, nous ne pouvons permettre à HO de 
prendre la valeur 2 ou 3, puisque c’est là que 
VIC-II voit l’image de caractère en ROM nor- 
male. Par ailleurs, de grandes valeurs de HO met- 
tront le haut de la mémoire HR hors d’atteinte de 
VIC-II. L’adresse correspondante de la base de 
l’écran matrice de caractère/haute résolution 
(MC/HR) en mémoire est calculée comme suit : 


CM=WD+248"H0 (base de fenêtre plus décalé). 
ou : 
CM=16384"(3- (PEEK(56576)AND3)) + 1024 
*(PEEK(53272)AND14) 


En mettant ces registres, nous pouvons déplacer 
toute la mémoire d’affichage vidéo de manière 
appropriée à notre programme. 


Coordonnée couleurs 

En mode d'affichage 
normal du C64, chaque bit 
mis à 1 dans les 8 octets 
qui définissent un 
caractère est affiché dans 
la couleur de fond en 
cours. Tous les bits mis à 
zéro sont affichés dans la 
couleur écran de fond. 
Lorsque le mode 
multicolore est sélectionné, 
les configurations de bits 
ne sont plus interprétées 
comme bits individuels 
mais comme paires. 

(CI. Liz Dixon.) 


d'affichage norm 
dd. 100 


a et 


000010 
000010 
| ou nn 
Oii::00 
00000000 


0'0:e “OA! 010 0/0 
001 ire TES 00 
01. T'ON ONE 
0) mis rt Ari Le 2 
O1" 010" 107. "TO 
01-107 0% 70 
91, 10 "O1 10 
00 00 00 00 
Clé 


D 0 muLTICOLORE 1 


10 MULTICOLORE 2 


 HRUTOVNE 


00 COULEUR 
D'ARRIÈRE-PLAN 
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Problèmes à résoudre 
L'objectif de Knight Lore 
est d'apporter jusqu'au 
chaudron les objets 
nécessaires, afin 
d'empêcher le chevalier 
d'être transformé en loup- 
garou. Pour ce faire, 

le chevalier doit d’abord 
rendre visite au sorcier 
pour déterminer ce dont il 
a besoin. La recherche 
peut alors commencer. 
Bien que les objets 
puissent changer de 
position, ils se trouvent 
toujours dans la même 
pièce. 

(CI. lan McKinnell.) 
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Un conte de fée 


Après avoir créé des jeux très populaires, 
Ultimate vient d’introduire un type de jeu entièrement différent, 
Knight Lore, avec des graphiques tridimensionnels. 


Ultimate a toujours eu la réputation de produire 
des jeux de qualité pour le Sinclair Spectrum. 
Cette société a créé une série complète de jeux- 
labyrinthes style « arcade » dans lesquels le 
joueur doit se frayer un chemin à travers de nom- 
breuses pièces habitées par des créatures étran- 
ges et mystérieuses. Pendant ce temps, le joueur 
doit également découvrir divers objets, talismans 
et bibelots mystérieux, qui, une fois rassemblés, 
mettront fin au jeu. Atic Atac et Sabre Wulf en 
sont des exemples. 

Malgré la popularité de ces jeux auprès des uti- 
lisateurs de Spectrum, la société a maintenant 
décidé de s’éloigner des jeux d’aventures bidi- 
mensionnels comme Sabre Wulf. Bien que sem- 
blable aux créations antérieures d’Ultimate, 
Knight Lore est très différent. Le scénario est le 
suivant : un chevalier (en fait, le héros de plu- 
sieurs aventures précédentes, Sabre Man) doit 
trouver le château d’un sorcier afin d’obtenir la 
formule magique qui l’empêchera d’être trans- 
formé en loup-garou. Le joueur dispose de qua- 
rante jours et de quarante nuits pour trouver la 
solution ; le déroulement de ceux-ci est affiché au 
bas de l’écran; et dans le coin inférieur droit 
apparaît une fenêtre renfermant un « cadran 
solaire ». Pendant le jour, le joueur est Sabre 
Man. Cependant, lorsque la lune se lève dans la 
fenêtre, il est transformé de façon assez specta- 
culaire en loup-garou. Heureusement, cette trans- 
formation ne gêne en rien les déplacements du 
joueur, sauf au cours de la transformation elle- 
même, qui peut poser un problème si vous êtes 
à ce moment précis poursuivi par une gargouille. 

Au début du jeu, vous remarquerez certaine- 
ment qu’il est tridimensionnel. Ces graphiques 
sont les meilleurs qui aient été produits sur le 
Spectrum, même en incluant Ant Attack. Cepen- 
dant, vous ne pouvez changer l’angle de vision 
sur Knight Lore; mais cette contrainte est 
compensée par la construction ingénieuse des 
diverses pièces. 

Knight Lore n’est pas un jeu d’aventures au 
sens propre, mais une série d’énigmes logiques. 
De ce point de vue, Knight Lore ressemble à un 
véritable jeu d’aventures, posant des problèmes 
complexes qui doivent être résolus avant de pour- 
suivre plus avant. Bien que de nombreuses 
pièces soient vides, d’autres vous placent devant 
diverses difficultés avant que vous n’atteigniez la 
sortie. 

Les énigmes présentent divers niveaux de dif- 
ficultés. Certaines sont relativement faciles, ou 
réellement complexes, et d’autres sont presque 


insolubles. Vous pouvez entrer dans une pièce 
contenant des blocs sur lesquels ont été placées 
de grosses sphères hérissées de clous. Si vous ten- 
tez de traverser les blocs, votre enthousiasme ris- 
que d’être refroidi assez rapidement — la solu- 
tion consiste simplement à contourner les blocs! 
Une autre astuce utilisée par les programmeurs 
consiste à employer une perspective déformée que 
l’on obtient lorsque l’on voit une représentation 
bidimensionnelle d’un espace tridimensionnel. 
Souvent, les blocs, qui semblent posés sur le sol, 
flottent en fait librement dans l’air et, si Sabre 
Man heurte un de ces blocs, il perd automatique- 
ment une vie et doit de nouveau essayer de tra- 
verser la pièce. 

Dans de nombreuses pièces, des objets doivent 
être recueillis, comme des pierres précieuses, des 
coupes et des potions. Pour les ramasser lorsque 
vous les découvrez, vous n’avez qu’à bondir sur 
l’objet et ramener le manche à balai vers l’arrière. 
Cela place l’objet dans votre « inventaire », qui 
est affiché dans le coin inférieur gauche de 
l’écran. Cette manœuvre peut vous permettre 
d’obtenir une hauteur supplémentaire lors de 
l’escalade d’un mur trop haut. 

Sabre Man peut se déplacer dans quatre direc- 
tions en utilisant soit le clavier, soit le manche 
à balai. Les sauts sont effectués par la pression 
d’une des touches de la troisième rangée du cla- 
vier ou du bouton de mise à feu. La correction 
de l’orientation de Sabre Man est essentielle pour 
exécuter un jeu avec succès — un saut effectué 
dans la mauvaise direction par exemple pourrait 
être fatal. Il se peut que vous deviez consacrer 
les premiers jeux à vous familiariser avec la 
commande de l’orientation puisque le manche à 
balai est très sensible et réagit à la moindre 
pression. 

Knight Lore est un jeu fascinant, d’aussi bonne 
qualité que les jeux Ultimate précédents. Même 
les joueurs qui n’aiment pas résoudre des 
énigmes seront fascinés par le jeu, puisque les 
solutions de nombreux problèmes n’exigent 
qu’une réaction rapide au clavier ou sur le bou- 
ton de mise à feu, tout en demandant une atten- 
tion et une vivacité permanentes. 
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